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/f32-pavgpool-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(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_fulltile)25*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_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(4)
31*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
32*4bdc9457SAndroid Build Coastguard Worker }
33*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_fulltile_with_input_offset)34*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_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(4)
40*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
41*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
42*4bdc9457SAndroid Build Coastguard Worker }
43*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_fulltile_with_zero)44*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_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(4)
51*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
52*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
53*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
54*4bdc9457SAndroid Build Coastguard Worker }
55*4bdc9457SAndroid Build Coastguard Worker }
56*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_fulltile_with_qmin)57*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_twopass_fulltile_with_qmin) {
58*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
59*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
60*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
61*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
62*4bdc9457SAndroid Build Coastguard Worker .channels(4)
63*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
64*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
65*4bdc9457SAndroid Build Coastguard Worker }
66*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_fulltile_with_qmax)67*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_twopass_fulltile_with_qmax) {
68*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
69*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
70*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
71*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
72*4bdc9457SAndroid Build Coastguard Worker .channels(4)
73*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
74*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
75*4bdc9457SAndroid Build Coastguard Worker }
76*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_subtile)77*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_twopass_subtile) {
78*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
79*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
80*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
81*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
82*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
83*4bdc9457SAndroid Build Coastguard Worker .channels(4)
84*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
85*4bdc9457SAndroid Build Coastguard Worker }
86*4bdc9457SAndroid Build Coastguard Worker }
87*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_subtile_with_input_offset)88*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_twopass_subtile_with_input_offset) {
89*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
90*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
91*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
92*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
93*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
94*4bdc9457SAndroid Build Coastguard Worker .channels(4)
95*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
96*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
97*4bdc9457SAndroid Build Coastguard Worker }
98*4bdc9457SAndroid Build Coastguard Worker }
99*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_twopass_subtile_with_zero)100*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_twopass_subtile_with_zero) {
101*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
102*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
103*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
104*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
105*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
106*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
107*4bdc9457SAndroid Build Coastguard Worker .channels(4)
108*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
109*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
110*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
111*4bdc9457SAndroid Build Coastguard Worker }
112*4bdc9457SAndroid Build Coastguard Worker }
113*4bdc9457SAndroid Build Coastguard Worker }
114*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_fulltile)115*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_fulltile) {
116*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
117*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
118*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
119*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
120*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
121*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
122*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
123*4bdc9457SAndroid Build Coastguard Worker }
124*4bdc9457SAndroid Build Coastguard Worker }
125*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_fulltile_with_input_offset)126*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_fulltile_with_input_offset) {
127*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
128*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
129*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
130*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
131*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
132*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
133*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
134*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
135*4bdc9457SAndroid Build Coastguard Worker }
136*4bdc9457SAndroid Build Coastguard Worker }
137*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_fulltile_with_zero)138*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_fulltile_with_zero) {
139*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
140*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
141*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
142*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
143*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
144*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
145*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
146*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
147*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
148*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
149*4bdc9457SAndroid Build Coastguard Worker }
150*4bdc9457SAndroid Build Coastguard Worker }
151*4bdc9457SAndroid Build Coastguard Worker }
152*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_fulltile_with_qmin)153*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_fulltile_with_qmin) {
154*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
155*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
156*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
157*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
158*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
159*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
160*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
161*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
162*4bdc9457SAndroid Build Coastguard Worker }
163*4bdc9457SAndroid Build Coastguard Worker }
164*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_fulltile_with_qmax)165*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_fulltile_with_qmax) {
166*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
167*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
168*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
169*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
170*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
171*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
172*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
174*4bdc9457SAndroid Build Coastguard Worker }
175*4bdc9457SAndroid Build Coastguard Worker }
176*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_subtile)177*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_subtile) {
178*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
179*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
180*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
181*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
182*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
183*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
184*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
185*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
186*4bdc9457SAndroid Build Coastguard Worker }
187*4bdc9457SAndroid Build Coastguard Worker }
188*4bdc9457SAndroid Build Coastguard Worker }
189*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_subtile_with_input_offset)190*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_subtile_with_input_offset) {
191*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
192*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
193*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
194*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
195*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
196*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
197*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
198*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
199*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
200*4bdc9457SAndroid Build Coastguard Worker }
201*4bdc9457SAndroid Build Coastguard Worker }
202*4bdc9457SAndroid Build Coastguard Worker }
203*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_twopass_subtile_with_zero)204*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_twopass_subtile_with_zero) {
205*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
206*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
207*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
208*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
209*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
210*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
211*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
212*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
213*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
214*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
215*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
216*4bdc9457SAndroid Build Coastguard Worker }
217*4bdc9457SAndroid Build Coastguard Worker }
218*4bdc9457SAndroid Build Coastguard Worker }
219*4bdc9457SAndroid Build Coastguard Worker }
220*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_fulltile)221*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_fulltile) {
222*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
223*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
224*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
225*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
226*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
227*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
228*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker }
231*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_fulltile_with_input_offset)232*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_fulltile_with_input_offset) {
233*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
234*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
235*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
236*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
237*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
238*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
239*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
241*4bdc9457SAndroid Build Coastguard Worker }
242*4bdc9457SAndroid Build Coastguard Worker }
243*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_fulltile_with_zero_index)244*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_fulltile_with_zero_index) {
245*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
246*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
247*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
248*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
249*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
250*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
251*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
252*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
253*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
254*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
255*4bdc9457SAndroid Build Coastguard Worker }
256*4bdc9457SAndroid Build Coastguard Worker }
257*4bdc9457SAndroid Build Coastguard Worker }
258*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_fulltile_with_qmin)259*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_fulltile_with_qmin) {
260*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
261*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
262*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
263*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
264*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
265*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
266*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
267*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
268*4bdc9457SAndroid Build Coastguard Worker }
269*4bdc9457SAndroid Build Coastguard Worker }
270*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_fulltile_with_qmax)271*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_fulltile_with_qmax) {
272*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
273*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
274*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
275*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
276*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
277*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
278*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
279*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
280*4bdc9457SAndroid Build Coastguard Worker }
281*4bdc9457SAndroid Build Coastguard Worker }
282*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_subtile)283*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_subtile) {
284*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
285*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
286*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
287*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
288*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
289*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
290*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
291*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
292*4bdc9457SAndroid Build Coastguard Worker }
293*4bdc9457SAndroid Build Coastguard Worker }
294*4bdc9457SAndroid Build Coastguard Worker }
295*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_subtile_with_input_offset)296*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_subtile_with_input_offset) {
297*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
298*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
299*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
300*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
301*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
302*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
303*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
304*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
305*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
306*4bdc9457SAndroid Build Coastguard Worker }
307*4bdc9457SAndroid Build Coastguard Worker }
308*4bdc9457SAndroid Build Coastguard Worker }
309*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_twopass_subtile_with_zero)310*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_twopass_subtile_with_zero) {
311*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
312*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
313*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
314*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
315*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
316*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
317*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
318*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
319*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
320*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
321*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
322*4bdc9457SAndroid Build Coastguard Worker }
323*4bdc9457SAndroid Build Coastguard Worker }
324*4bdc9457SAndroid Build Coastguard Worker }
325*4bdc9457SAndroid Build Coastguard Worker }
326*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_fulltile)327*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_fulltile) {
328*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
329*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
330*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
331*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
332*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
333*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
334*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
335*4bdc9457SAndroid Build Coastguard Worker }
336*4bdc9457SAndroid Build Coastguard Worker }
337*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_fulltile_with_input_offset)338*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_fulltile_with_input_offset) {
339*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
340*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
341*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
342*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
343*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
344*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
345*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
346*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
347*4bdc9457SAndroid Build Coastguard Worker }
348*4bdc9457SAndroid Build Coastguard Worker }
349*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_fulltile_with_zero)350*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_fulltile_with_zero) {
351*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
352*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
353*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
354*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
355*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
356*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
357*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
358*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
359*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
360*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
361*4bdc9457SAndroid Build Coastguard Worker }
362*4bdc9457SAndroid Build Coastguard Worker }
363*4bdc9457SAndroid Build Coastguard Worker }
364*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_fulltile_with_qmin)365*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_fulltile_with_qmin) {
366*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
367*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
368*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
369*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
370*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
371*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
372*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
373*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
374*4bdc9457SAndroid Build Coastguard Worker }
375*4bdc9457SAndroid Build Coastguard Worker }
376*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_fulltile_with_qmax)377*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_fulltile_with_qmax) {
378*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
379*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
380*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
381*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
382*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
383*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
384*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
385*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
386*4bdc9457SAndroid Build Coastguard Worker }
387*4bdc9457SAndroid Build Coastguard Worker }
388*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_subtile)389*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_subtile) {
390*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
391*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
392*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
393*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
394*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
395*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
396*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
397*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
398*4bdc9457SAndroid Build Coastguard Worker }
399*4bdc9457SAndroid Build Coastguard Worker }
400*4bdc9457SAndroid Build Coastguard Worker }
401*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_subtile_with_input_offset)402*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_subtile_with_input_offset) {
403*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
404*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
405*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
406*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
407*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
408*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
409*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
410*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
412*4bdc9457SAndroid Build Coastguard Worker }
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker }
415*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_twopass_subtile_with_zero)416*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_twopass_subtile_with_zero) {
417*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
418*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
419*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
420*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
421*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
422*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
423*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
424*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
425*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
426*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
427*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
428*4bdc9457SAndroid Build Coastguard Worker }
429*4bdc9457SAndroid Build Coastguard Worker }
430*4bdc9457SAndroid Build Coastguard Worker }
431*4bdc9457SAndroid Build Coastguard Worker }
432*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_multipass)433*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_multipass) {
434*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
435*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
436*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
437*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
438*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
439*4bdc9457SAndroid Build Coastguard Worker .channels(4)
440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
441*4bdc9457SAndroid Build Coastguard Worker }
442*4bdc9457SAndroid Build Coastguard Worker }
443*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_multipass_with_input_offset)444*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_multipass_with_input_offset) {
445*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
446*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
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(4)
451*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
452*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
453*4bdc9457SAndroid Build Coastguard Worker }
454*4bdc9457SAndroid Build Coastguard Worker }
455*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_multipass_with_zero)456*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_multipass_with_zero) {
457*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
458*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
459*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
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(4)
464*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
465*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
466*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
467*4bdc9457SAndroid Build Coastguard Worker }
468*4bdc9457SAndroid Build Coastguard Worker }
469*4bdc9457SAndroid Build Coastguard Worker }
470*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_multipass_with_qmin)471*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_multipass_with_qmin) {
472*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
473*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
474*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
475*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
476*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
477*4bdc9457SAndroid Build Coastguard Worker .channels(4)
478*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
479*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
480*4bdc9457SAndroid Build Coastguard Worker }
481*4bdc9457SAndroid Build Coastguard Worker }
482*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_eq_4_multipass_with_qmax)483*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_eq_4_multipass_with_qmax) {
484*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
485*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
486*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
487*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
488*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
489*4bdc9457SAndroid Build Coastguard Worker .channels(4)
490*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
491*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
492*4bdc9457SAndroid Build Coastguard Worker }
493*4bdc9457SAndroid Build Coastguard Worker }
494*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_multipass)495*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_multipass) {
496*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
497*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
498*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
499*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
500*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
501*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
502*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
503*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
504*4bdc9457SAndroid Build Coastguard Worker }
505*4bdc9457SAndroid Build Coastguard Worker }
506*4bdc9457SAndroid Build Coastguard Worker }
507*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_multipass_with_input_offset)508*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_multipass_with_input_offset) {
509*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
510*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
511*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
512*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
513*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
514*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
515*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
516*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
517*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
518*4bdc9457SAndroid Build Coastguard Worker }
519*4bdc9457SAndroid Build Coastguard Worker }
520*4bdc9457SAndroid Build Coastguard Worker }
521*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_multipass_with_zero)522*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_multipass_with_zero) {
523*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
524*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
525*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
526*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
527*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
528*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
529*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
530*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
531*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
532*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
533*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
534*4bdc9457SAndroid Build Coastguard Worker }
535*4bdc9457SAndroid Build Coastguard Worker }
536*4bdc9457SAndroid Build Coastguard Worker }
537*4bdc9457SAndroid Build Coastguard Worker }
538*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_multipass_with_qmin)539*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_multipass_with_qmin) {
540*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
541*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
542*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
543*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
544*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
545*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
546*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
547*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
548*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
549*4bdc9457SAndroid Build Coastguard Worker }
550*4bdc9457SAndroid Build Coastguard Worker }
551*4bdc9457SAndroid Build Coastguard Worker }
552*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_div_4_multipass_with_qmax)553*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_div_4_multipass_with_qmax) {
554*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
555*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
556*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
557*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
558*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
559*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
560*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
561*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
562*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
563*4bdc9457SAndroid Build Coastguard Worker }
564*4bdc9457SAndroid Build Coastguard Worker }
565*4bdc9457SAndroid Build Coastguard Worker }
566*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_multipass)567*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_multipass) {
568*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
569*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
570*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
571*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
572*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
573*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
574*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
575*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
576*4bdc9457SAndroid Build Coastguard Worker }
577*4bdc9457SAndroid Build Coastguard Worker }
578*4bdc9457SAndroid Build Coastguard Worker }
579*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_multipass_with_input_offset)580*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_multipass_with_input_offset) {
581*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
582*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
583*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
584*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
585*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
586*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
587*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
588*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
589*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
590*4bdc9457SAndroid Build Coastguard Worker }
591*4bdc9457SAndroid Build Coastguard Worker }
592*4bdc9457SAndroid Build Coastguard Worker }
593*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_multipass_with_zero)594*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_multipass_with_zero) {
595*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
596*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
597*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
598*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
599*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
600*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
601*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
602*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
603*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
604*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
606*4bdc9457SAndroid Build Coastguard Worker }
607*4bdc9457SAndroid Build Coastguard Worker }
608*4bdc9457SAndroid Build Coastguard Worker }
609*4bdc9457SAndroid Build Coastguard Worker }
610*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_multipass_with_qmin)611*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_multipass_with_qmin) {
612*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
613*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
614*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
615*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
616*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
617*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
618*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
619*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
620*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
621*4bdc9457SAndroid Build Coastguard Worker }
622*4bdc9457SAndroid Build Coastguard Worker }
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_lt_4_multipass_with_qmax)625*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_lt_4_multipass_with_qmax) {
626*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
627*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
628*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
629*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
630*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
631*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
632*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
633*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker }
638*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_multipass)639*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_multipass) {
640*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
641*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
642*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
643*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
644*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
645*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
646*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
647*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
648*4bdc9457SAndroid Build Coastguard Worker }
649*4bdc9457SAndroid Build Coastguard Worker }
650*4bdc9457SAndroid Build Coastguard Worker }
651*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_multipass_with_input_offset)652*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_multipass_with_input_offset) {
653*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
654*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
655*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
656*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
657*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
658*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
659*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
660*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
661*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
662*4bdc9457SAndroid Build Coastguard Worker }
663*4bdc9457SAndroid Build Coastguard Worker }
664*4bdc9457SAndroid Build Coastguard Worker }
665*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_multipass_with_zero)666*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_multipass_with_zero) {
667*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
668*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
669*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
670*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
671*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
672*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
673*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
674*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
675*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
676*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
677*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
678*4bdc9457SAndroid Build Coastguard Worker }
679*4bdc9457SAndroid Build Coastguard Worker }
680*4bdc9457SAndroid Build Coastguard Worker }
681*4bdc9457SAndroid Build Coastguard Worker }
682*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_multipass_with_qmin)683*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_multipass_with_qmin) {
684*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
685*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
686*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
687*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
688*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
689*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
690*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
691*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
692*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
693*4bdc9457SAndroid Build Coastguard Worker }
694*4bdc9457SAndroid Build Coastguard Worker }
695*4bdc9457SAndroid Build Coastguard Worker }
696*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,channels_gt_4_multipass_with_qmax)697*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, channels_gt_4_multipass_with_qmax) {
698*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
699*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
700*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
701*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
702*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
703*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
704*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
705*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
706*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
707*4bdc9457SAndroid Build Coastguard Worker }
708*4bdc9457SAndroid Build Coastguard Worker }
709*4bdc9457SAndroid Build Coastguard Worker }
710*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels)711*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels) {
712*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
713*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
714*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
715*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
716*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
717*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
718*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
719*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
720*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
721*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
722*4bdc9457SAndroid Build Coastguard Worker }
723*4bdc9457SAndroid Build Coastguard Worker }
724*4bdc9457SAndroid Build Coastguard Worker }
725*4bdc9457SAndroid Build Coastguard Worker }
726*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_input_offset)727*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_input_offset) {
728*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
729*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
730*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
731*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
732*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
733*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
734*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
735*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
736*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
737*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
738*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
739*4bdc9457SAndroid Build Coastguard Worker }
740*4bdc9457SAndroid Build Coastguard Worker }
741*4bdc9457SAndroid Build Coastguard Worker }
742*4bdc9457SAndroid Build Coastguard Worker }
743*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_zero)744*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_zero) {
745*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
746*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
747*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
748*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
749*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
750*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
751*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
752*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
753*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
754*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
755*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
756*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
758*4bdc9457SAndroid Build Coastguard Worker }
759*4bdc9457SAndroid Build Coastguard Worker }
760*4bdc9457SAndroid Build Coastguard Worker }
761*4bdc9457SAndroid Build Coastguard Worker }
762*4bdc9457SAndroid Build Coastguard Worker }
763*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_qmin)764*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_qmin) {
765*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
766*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
767*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
768*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
769*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
770*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
771*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
772*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
773*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
774*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
775*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
776*4bdc9457SAndroid Build Coastguard Worker }
777*4bdc9457SAndroid Build Coastguard Worker }
778*4bdc9457SAndroid Build Coastguard Worker }
779*4bdc9457SAndroid Build Coastguard Worker }
780*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_qmax)781*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_qmax) {
782*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
783*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
784*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
785*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
786*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
787*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
788*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
789*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
790*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
791*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
792*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
793*4bdc9457SAndroid Build Coastguard Worker }
794*4bdc9457SAndroid Build Coastguard Worker }
795*4bdc9457SAndroid Build Coastguard Worker }
796*4bdc9457SAndroid Build Coastguard Worker }
797*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_output_stride)798*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_output_stride) {
799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
800*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
801*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
802*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
803*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
804*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
805*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
806*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
807*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
808*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
809*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
810*4bdc9457SAndroid Build Coastguard Worker }
811*4bdc9457SAndroid Build Coastguard Worker }
812*4bdc9457SAndroid Build Coastguard Worker }
813*4bdc9457SAndroid Build Coastguard Worker }
814*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4,few_output_pixels_with_step)815*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__NEON_C4, few_output_pixels_with_step) {
816*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
817*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
818*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
819*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
820*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
821*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
822*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
823*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
824*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
825*4bdc9457SAndroid Build Coastguard Worker .step(step)
826*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
827*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
828*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__neon_c4, xnn_init_f32_minmax_scalar_params);
829*4bdc9457SAndroid Build Coastguard Worker }
830*4bdc9457SAndroid Build Coastguard Worker }
831*4bdc9457SAndroid Build Coastguard Worker }
832*4bdc9457SAndroid Build Coastguard Worker }
833*4bdc9457SAndroid Build Coastguard Worker }
834*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
835*4bdc9457SAndroid Build Coastguard Worker
836*4bdc9457SAndroid Build Coastguard Worker
837*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_fulltile)838*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_fulltile) {
839*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
840*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
841*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
842*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
843*4bdc9457SAndroid Build Coastguard Worker .channels(4)
844*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_fulltile_with_input_offset)847*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_fulltile_with_input_offset) {
848*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
849*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
850*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
851*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
852*4bdc9457SAndroid Build Coastguard Worker .channels(4)
853*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
855*4bdc9457SAndroid Build Coastguard Worker }
856*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_fulltile_with_zero)857*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_fulltile_with_zero) {
858*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
859*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
860*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
861*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
862*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
863*4bdc9457SAndroid Build Coastguard Worker .channels(4)
864*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
865*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
866*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
867*4bdc9457SAndroid Build Coastguard Worker }
868*4bdc9457SAndroid Build Coastguard Worker }
869*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_fulltile_with_qmin)870*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_fulltile_with_qmin) {
871*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
872*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
873*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
874*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
875*4bdc9457SAndroid Build Coastguard Worker .channels(4)
876*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
877*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
878*4bdc9457SAndroid Build Coastguard Worker }
879*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_fulltile_with_qmax)880*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_fulltile_with_qmax) {
881*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
882*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
883*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
884*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
885*4bdc9457SAndroid Build Coastguard Worker .channels(4)
886*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
888*4bdc9457SAndroid Build Coastguard Worker }
889*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_subtile)890*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_subtile) {
891*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
892*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
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(4)
897*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
898*4bdc9457SAndroid Build Coastguard Worker }
899*4bdc9457SAndroid Build Coastguard Worker }
900*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_subtile_with_input_offset)901*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_subtile_with_input_offset) {
902*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
903*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
904*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
905*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
906*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
907*4bdc9457SAndroid Build Coastguard Worker .channels(4)
908*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
909*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
910*4bdc9457SAndroid Build Coastguard Worker }
911*4bdc9457SAndroid Build Coastguard Worker }
912*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_twopass_subtile_with_zero)913*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_twopass_subtile_with_zero) {
914*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
915*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
916*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
917*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
918*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
919*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
920*4bdc9457SAndroid Build Coastguard Worker .channels(4)
921*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
922*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
923*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
924*4bdc9457SAndroid Build Coastguard Worker }
925*4bdc9457SAndroid Build Coastguard Worker }
926*4bdc9457SAndroid Build Coastguard Worker }
927*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_fulltile)928*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_fulltile) {
929*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
930*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
931*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
932*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
933*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
934*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
935*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
936*4bdc9457SAndroid Build Coastguard Worker }
937*4bdc9457SAndroid Build Coastguard Worker }
938*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_fulltile_with_input_offset)939*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_fulltile_with_input_offset) {
940*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
941*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
942*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
943*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
944*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
945*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
946*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
947*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
948*4bdc9457SAndroid Build Coastguard Worker }
949*4bdc9457SAndroid Build Coastguard Worker }
950*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_fulltile_with_zero)951*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_fulltile_with_zero) {
952*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
953*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
954*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
955*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
956*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
957*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
958*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
959*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
960*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
961*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
962*4bdc9457SAndroid Build Coastguard Worker }
963*4bdc9457SAndroid Build Coastguard Worker }
964*4bdc9457SAndroid Build Coastguard Worker }
965*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_fulltile_with_qmin)966*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_fulltile_with_qmin) {
967*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
968*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
969*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
970*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
971*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
972*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
973*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
974*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
975*4bdc9457SAndroid Build Coastguard Worker }
976*4bdc9457SAndroid Build Coastguard Worker }
977*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_fulltile_with_qmax)978*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_fulltile_with_qmax) {
979*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
980*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
981*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
982*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
983*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
984*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
985*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
986*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
987*4bdc9457SAndroid Build Coastguard Worker }
988*4bdc9457SAndroid Build Coastguard Worker }
989*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_subtile)990*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_subtile) {
991*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
992*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
993*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
994*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
995*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
996*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
997*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
998*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
999*4bdc9457SAndroid Build Coastguard Worker }
1000*4bdc9457SAndroid Build Coastguard Worker }
1001*4bdc9457SAndroid Build Coastguard Worker }
1002*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_subtile_with_input_offset)1003*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_subtile_with_input_offset) {
1004*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1005*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1006*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1007*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1008*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1009*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1010*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1011*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1012*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1013*4bdc9457SAndroid Build Coastguard Worker }
1014*4bdc9457SAndroid Build Coastguard Worker }
1015*4bdc9457SAndroid Build Coastguard Worker }
1016*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_twopass_subtile_with_zero)1017*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_twopass_subtile_with_zero) {
1018*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1019*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1020*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1021*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1022*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1023*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1024*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1025*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1026*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1027*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1029*4bdc9457SAndroid Build Coastguard Worker }
1030*4bdc9457SAndroid Build Coastguard Worker }
1031*4bdc9457SAndroid Build Coastguard Worker }
1032*4bdc9457SAndroid Build Coastguard Worker }
1033*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_fulltile)1034*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_fulltile) {
1035*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1036*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1037*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1038*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1039*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1040*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1042*4bdc9457SAndroid Build Coastguard Worker }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_fulltile_with_input_offset)1045*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_fulltile_with_input_offset) {
1046*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1047*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1048*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1049*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1050*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1051*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1052*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1053*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1054*4bdc9457SAndroid Build Coastguard Worker }
1055*4bdc9457SAndroid Build Coastguard Worker }
1056*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_fulltile_with_zero_index)1057*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_fulltile_with_zero_index) {
1058*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1059*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1060*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1061*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1062*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1063*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1064*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1065*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1066*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1067*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1068*4bdc9457SAndroid Build Coastguard Worker }
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker }
1071*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_fulltile_with_qmin)1072*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_fulltile_with_qmin) {
1073*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1074*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1075*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1076*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1077*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1078*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1079*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1081*4bdc9457SAndroid Build Coastguard Worker }
1082*4bdc9457SAndroid Build Coastguard Worker }
1083*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_fulltile_with_qmax)1084*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_fulltile_with_qmax) {
1085*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1086*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1087*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1088*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1089*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1090*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1091*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1092*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1093*4bdc9457SAndroid Build Coastguard Worker }
1094*4bdc9457SAndroid Build Coastguard Worker }
1095*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_subtile)1096*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_subtile) {
1097*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1098*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1099*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1100*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1101*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1102*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1103*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1105*4bdc9457SAndroid Build Coastguard Worker }
1106*4bdc9457SAndroid Build Coastguard Worker }
1107*4bdc9457SAndroid Build Coastguard Worker }
1108*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_subtile_with_input_offset)1109*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_subtile_with_input_offset) {
1110*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1111*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1112*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1113*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1114*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1115*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1116*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1117*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1118*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1119*4bdc9457SAndroid Build Coastguard Worker }
1120*4bdc9457SAndroid Build Coastguard Worker }
1121*4bdc9457SAndroid Build Coastguard Worker }
1122*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_twopass_subtile_with_zero)1123*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_twopass_subtile_with_zero) {
1124*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1125*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1126*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1127*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1128*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1129*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1130*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1131*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1132*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1133*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1134*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1135*4bdc9457SAndroid Build Coastguard Worker }
1136*4bdc9457SAndroid Build Coastguard Worker }
1137*4bdc9457SAndroid Build Coastguard Worker }
1138*4bdc9457SAndroid Build Coastguard Worker }
1139*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_fulltile)1140*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_fulltile) {
1141*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1142*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1143*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1144*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1145*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1146*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1147*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1148*4bdc9457SAndroid Build Coastguard Worker }
1149*4bdc9457SAndroid Build Coastguard Worker }
1150*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_fulltile_with_input_offset)1151*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_fulltile_with_input_offset) {
1152*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1153*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1154*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1155*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1156*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1157*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1158*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1159*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1160*4bdc9457SAndroid Build Coastguard Worker }
1161*4bdc9457SAndroid Build Coastguard Worker }
1162*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_fulltile_with_zero)1163*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_fulltile_with_zero) {
1164*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1165*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1166*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1167*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1168*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1169*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1170*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1171*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1172*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1174*4bdc9457SAndroid Build Coastguard Worker }
1175*4bdc9457SAndroid Build Coastguard Worker }
1176*4bdc9457SAndroid Build Coastguard Worker }
1177*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_fulltile_with_qmin)1178*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_fulltile_with_qmin) {
1179*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1180*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1181*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1182*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1183*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1184*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1185*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1186*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1187*4bdc9457SAndroid Build Coastguard Worker }
1188*4bdc9457SAndroid Build Coastguard Worker }
1189*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_fulltile_with_qmax)1190*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_fulltile_with_qmax) {
1191*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1192*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1193*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1194*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1195*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1196*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1197*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1198*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1199*4bdc9457SAndroid Build Coastguard Worker }
1200*4bdc9457SAndroid Build Coastguard Worker }
1201*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_subtile)1202*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_subtile) {
1203*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1204*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1205*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1206*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1207*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1208*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1209*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1210*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1211*4bdc9457SAndroid Build Coastguard Worker }
1212*4bdc9457SAndroid Build Coastguard Worker }
1213*4bdc9457SAndroid Build Coastguard Worker }
1214*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_subtile_with_input_offset)1215*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_subtile_with_input_offset) {
1216*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1217*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1218*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1219*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1220*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1221*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1222*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1223*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1224*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1225*4bdc9457SAndroid Build Coastguard Worker }
1226*4bdc9457SAndroid Build Coastguard Worker }
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_twopass_subtile_with_zero)1229*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_twopass_subtile_with_zero) {
1230*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1231*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1232*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1233*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1234*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1235*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1236*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1237*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1238*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1239*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_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
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_multipass)1246*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_multipass) {
1247*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1248*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1249*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1250*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1251*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1252*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker }
1256*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_multipass_with_input_offset)1257*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_multipass_with_input_offset) {
1258*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1259*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1260*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1261*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1262*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1263*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1264*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1265*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1266*4bdc9457SAndroid Build Coastguard Worker }
1267*4bdc9457SAndroid Build Coastguard Worker }
1268*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_multipass_with_zero)1269*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_multipass_with_zero) {
1270*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1271*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1272*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1273*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1274*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1275*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1276*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1277*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1278*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1279*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1280*4bdc9457SAndroid Build Coastguard Worker }
1281*4bdc9457SAndroid Build Coastguard Worker }
1282*4bdc9457SAndroid Build Coastguard Worker }
1283*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_multipass_with_qmin)1284*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_multipass_with_qmin) {
1285*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1286*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1287*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1288*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1289*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1290*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1291*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1292*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1293*4bdc9457SAndroid Build Coastguard Worker }
1294*4bdc9457SAndroid Build Coastguard Worker }
1295*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_eq_4_multipass_with_qmax)1296*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_eq_4_multipass_with_qmax) {
1297*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1298*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1299*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1300*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1301*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1302*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1303*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1304*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1305*4bdc9457SAndroid Build Coastguard Worker }
1306*4bdc9457SAndroid Build Coastguard Worker }
1307*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_multipass)1308*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_multipass) {
1309*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1310*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1311*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1312*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1313*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1314*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1315*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1316*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1317*4bdc9457SAndroid Build Coastguard Worker }
1318*4bdc9457SAndroid Build Coastguard Worker }
1319*4bdc9457SAndroid Build Coastguard Worker }
1320*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_multipass_with_input_offset)1321*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_multipass_with_input_offset) {
1322*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1323*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1324*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1325*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1326*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1327*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1328*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1329*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1330*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1331*4bdc9457SAndroid Build Coastguard Worker }
1332*4bdc9457SAndroid Build Coastguard Worker }
1333*4bdc9457SAndroid Build Coastguard Worker }
1334*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_multipass_with_zero)1335*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_multipass_with_zero) {
1336*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1337*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1338*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1339*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1340*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1341*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1342*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1343*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1344*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1345*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1346*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1347*4bdc9457SAndroid Build Coastguard Worker }
1348*4bdc9457SAndroid Build Coastguard Worker }
1349*4bdc9457SAndroid Build Coastguard Worker }
1350*4bdc9457SAndroid Build Coastguard Worker }
1351*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_multipass_with_qmin)1352*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_multipass_with_qmin) {
1353*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1354*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1355*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1356*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1357*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1358*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1359*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1360*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1361*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1362*4bdc9457SAndroid Build Coastguard Worker }
1363*4bdc9457SAndroid Build Coastguard Worker }
1364*4bdc9457SAndroid Build Coastguard Worker }
1365*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_div_4_multipass_with_qmax)1366*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_div_4_multipass_with_qmax) {
1367*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1368*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1369*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1370*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1371*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1372*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1373*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1374*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1375*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker }
1378*4bdc9457SAndroid Build Coastguard Worker }
1379*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_multipass)1380*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_multipass) {
1381*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1382*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1383*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1384*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1385*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1386*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1387*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1388*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1389*4bdc9457SAndroid Build Coastguard Worker }
1390*4bdc9457SAndroid Build Coastguard Worker }
1391*4bdc9457SAndroid Build Coastguard Worker }
1392*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_multipass_with_input_offset)1393*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_multipass_with_input_offset) {
1394*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1395*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1396*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1397*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1398*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1399*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1400*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1401*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
1402*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1403*4bdc9457SAndroid Build Coastguard Worker }
1404*4bdc9457SAndroid Build Coastguard Worker }
1405*4bdc9457SAndroid Build Coastguard Worker }
1406*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_multipass_with_zero)1407*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_multipass_with_zero) {
1408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1409*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1410*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1411*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1412*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1413*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1414*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1415*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1416*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
1417*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1418*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1419*4bdc9457SAndroid Build Coastguard Worker }
1420*4bdc9457SAndroid Build Coastguard Worker }
1421*4bdc9457SAndroid Build Coastguard Worker }
1422*4bdc9457SAndroid Build Coastguard Worker }
1423*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_multipass_with_qmin)1424*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_multipass_with_qmin) {
1425*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1426*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1427*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1428*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1429*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1430*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1431*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1432*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1433*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1434*4bdc9457SAndroid Build Coastguard Worker }
1435*4bdc9457SAndroid Build Coastguard Worker }
1436*4bdc9457SAndroid Build Coastguard Worker }
1437*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_lt_4_multipass_with_qmax)1438*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_lt_4_multipass_with_qmax) {
1439*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1440*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1441*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1442*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1443*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1444*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1445*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1446*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1447*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1448*4bdc9457SAndroid Build Coastguard Worker }
1449*4bdc9457SAndroid Build Coastguard Worker }
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_multipass)1452*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_multipass) {
1453*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1454*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1455*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1456*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1457*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1458*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1459*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1460*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1461*4bdc9457SAndroid Build Coastguard Worker }
1462*4bdc9457SAndroid Build Coastguard Worker }
1463*4bdc9457SAndroid Build Coastguard Worker }
1464*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_multipass_with_input_offset)1465*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_multipass_with_input_offset) {
1466*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1467*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1468*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1469*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1470*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1471*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1472*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1473*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1474*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1475*4bdc9457SAndroid Build Coastguard Worker }
1476*4bdc9457SAndroid Build Coastguard Worker }
1477*4bdc9457SAndroid Build Coastguard Worker }
1478*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_multipass_with_zero)1479*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_multipass_with_zero) {
1480*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1481*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1482*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1483*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1484*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1485*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1486*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1487*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1488*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1489*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1490*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1491*4bdc9457SAndroid Build Coastguard Worker }
1492*4bdc9457SAndroid Build Coastguard Worker }
1493*4bdc9457SAndroid Build Coastguard Worker }
1494*4bdc9457SAndroid Build Coastguard Worker }
1495*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_multipass_with_qmin)1496*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_multipass_with_qmin) {
1497*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1498*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1499*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1500*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1501*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1502*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1503*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1504*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1505*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1506*4bdc9457SAndroid Build Coastguard Worker }
1507*4bdc9457SAndroid Build Coastguard Worker }
1508*4bdc9457SAndroid Build Coastguard Worker }
1509*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,channels_gt_4_multipass_with_qmax)1510*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, channels_gt_4_multipass_with_qmax) {
1511*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1512*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
1513*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1514*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1515*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1516*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1517*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1518*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1519*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1520*4bdc9457SAndroid Build Coastguard Worker }
1521*4bdc9457SAndroid Build Coastguard Worker }
1522*4bdc9457SAndroid Build Coastguard Worker }
1523*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels)1524*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels) {
1525*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1526*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1527*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1528*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1529*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1530*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1531*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1532*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1533*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1534*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1535*4bdc9457SAndroid Build Coastguard Worker }
1536*4bdc9457SAndroid Build Coastguard Worker }
1537*4bdc9457SAndroid Build Coastguard Worker }
1538*4bdc9457SAndroid Build Coastguard Worker }
1539*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_input_offset)1540*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_input_offset) {
1541*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1542*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1543*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1544*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1545*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1546*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1547*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1548*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1549*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1550*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
1551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1552*4bdc9457SAndroid Build Coastguard Worker }
1553*4bdc9457SAndroid Build Coastguard Worker }
1554*4bdc9457SAndroid Build Coastguard Worker }
1555*4bdc9457SAndroid Build Coastguard Worker }
1556*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_zero)1557*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_zero) {
1558*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1559*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1560*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1561*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1562*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1563*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1564*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1565*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1566*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1567*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1568*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
1569*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1570*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1571*4bdc9457SAndroid Build Coastguard Worker }
1572*4bdc9457SAndroid Build Coastguard Worker }
1573*4bdc9457SAndroid Build Coastguard Worker }
1574*4bdc9457SAndroid Build Coastguard Worker }
1575*4bdc9457SAndroid Build Coastguard Worker }
1576*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_qmin)1577*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_qmin) {
1578*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1579*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1580*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1581*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1582*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1583*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1584*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1585*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1586*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1587*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1588*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1589*4bdc9457SAndroid Build Coastguard Worker }
1590*4bdc9457SAndroid Build Coastguard Worker }
1591*4bdc9457SAndroid Build Coastguard Worker }
1592*4bdc9457SAndroid Build Coastguard Worker }
1593*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_qmax)1594*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_qmax) {
1595*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1596*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1597*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1598*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1599*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1600*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1601*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1602*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1603*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1604*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1606*4bdc9457SAndroid Build Coastguard Worker }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker }
1609*4bdc9457SAndroid Build Coastguard Worker }
1610*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_output_stride)1611*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_output_stride) {
1612*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1613*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1614*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1615*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1616*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1617*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1618*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1619*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1620*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1621*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
1622*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1623*4bdc9457SAndroid Build Coastguard Worker }
1624*4bdc9457SAndroid Build Coastguard Worker }
1625*4bdc9457SAndroid Build Coastguard Worker }
1626*4bdc9457SAndroid Build Coastguard Worker }
1627*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4,few_output_pixels_with_step)1628*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SSE_C4, few_output_pixels_with_step) {
1629*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
1630*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
1631*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
1632*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
1633*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
1634*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1635*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
1636*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1637*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1638*4bdc9457SAndroid Build Coastguard Worker .step(step)
1639*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1640*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
1641*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__sse_c4, xnn_init_f32_minmax_sse_params);
1642*4bdc9457SAndroid Build Coastguard Worker }
1643*4bdc9457SAndroid Build Coastguard Worker }
1644*4bdc9457SAndroid Build Coastguard Worker }
1645*4bdc9457SAndroid Build Coastguard Worker }
1646*4bdc9457SAndroid Build Coastguard Worker }
1647*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1648*4bdc9457SAndroid Build Coastguard Worker
1649*4bdc9457SAndroid Build Coastguard Worker
1650*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_fulltile)1651*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_fulltile) {
1652*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1653*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1654*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1655*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1656*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1657*4bdc9457SAndroid Build Coastguard Worker }
1658*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_fulltile_with_input_offset)1659*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_fulltile_with_input_offset) {
1660*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1661*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1662*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1663*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1664*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1665*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1666*4bdc9457SAndroid Build Coastguard Worker }
1667*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_fulltile_with_zero)1668*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_fulltile_with_zero) {
1669*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1670*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1671*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1672*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1673*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1674*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1675*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1676*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1677*4bdc9457SAndroid Build Coastguard Worker }
1678*4bdc9457SAndroid Build Coastguard Worker }
1679*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_fulltile_with_qmin)1680*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_fulltile_with_qmin) {
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(4)
1685*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1686*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1687*4bdc9457SAndroid Build Coastguard Worker }
1688*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_fulltile_with_qmax)1689*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_fulltile_with_qmax) {
1690*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1691*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1692*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1693*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1694*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1695*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1696*4bdc9457SAndroid Build Coastguard Worker }
1697*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_subtile)1698*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_subtile) {
1699*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1700*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1701*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1702*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1703*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1704*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1705*4bdc9457SAndroid Build Coastguard Worker }
1706*4bdc9457SAndroid Build Coastguard Worker }
1707*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_subtile_with_input_offset)1708*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_subtile_with_input_offset) {
1709*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1710*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1711*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1712*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1713*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1714*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1715*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1716*4bdc9457SAndroid Build Coastguard Worker }
1717*4bdc9457SAndroid Build Coastguard Worker }
1718*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_twopass_subtile_with_zero)1719*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_twopass_subtile_with_zero) {
1720*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1721*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1722*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1723*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1724*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1725*4bdc9457SAndroid Build Coastguard Worker .channels(4)
1726*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
1727*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1729*4bdc9457SAndroid Build Coastguard Worker }
1730*4bdc9457SAndroid Build Coastguard Worker }
1731*4bdc9457SAndroid Build Coastguard Worker }
1732*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_fulltile)1733*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_fulltile) {
1734*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1735*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1736*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1737*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1738*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1739*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1740*4bdc9457SAndroid Build Coastguard Worker }
1741*4bdc9457SAndroid Build Coastguard Worker }
1742*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_fulltile_with_input_offset)1743*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_fulltile_with_input_offset) {
1744*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1745*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1746*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1747*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1748*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1749*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
1750*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1751*4bdc9457SAndroid Build Coastguard Worker }
1752*4bdc9457SAndroid Build Coastguard Worker }
1753*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_fulltile_with_zero)1754*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_fulltile_with_zero) {
1755*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1756*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1757*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1758*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1759*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1760*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1761*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
1762*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1763*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1764*4bdc9457SAndroid Build Coastguard Worker }
1765*4bdc9457SAndroid Build Coastguard Worker }
1766*4bdc9457SAndroid Build Coastguard Worker }
1767*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_fulltile_with_qmin)1768*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_fulltile_with_qmin) {
1769*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1770*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1771*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1772*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1773*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1774*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1775*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1776*4bdc9457SAndroid Build Coastguard Worker }
1777*4bdc9457SAndroid Build Coastguard Worker }
1778*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_fulltile_with_qmax)1779*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_fulltile_with_qmax) {
1780*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1781*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1782*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1783*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1784*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1785*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1786*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1787*4bdc9457SAndroid Build Coastguard Worker }
1788*4bdc9457SAndroid Build Coastguard Worker }
1789*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_subtile)1790*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_subtile) {
1791*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1792*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1793*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1794*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1795*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1796*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1797*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1798*4bdc9457SAndroid Build Coastguard Worker }
1799*4bdc9457SAndroid Build Coastguard Worker }
1800*4bdc9457SAndroid Build Coastguard Worker }
1801*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_subtile_with_input_offset)1802*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_subtile_with_input_offset) {
1803*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1804*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1805*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1806*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1807*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1808*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1809*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1810*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1811*4bdc9457SAndroid Build Coastguard Worker }
1812*4bdc9457SAndroid Build Coastguard Worker }
1813*4bdc9457SAndroid Build Coastguard Worker }
1814*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_twopass_subtile_with_zero)1815*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_twopass_subtile_with_zero) {
1816*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1817*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
1818*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1819*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1820*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1821*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1822*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1823*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
1824*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1825*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1826*4bdc9457SAndroid Build Coastguard Worker }
1827*4bdc9457SAndroid Build Coastguard Worker }
1828*4bdc9457SAndroid Build Coastguard Worker }
1829*4bdc9457SAndroid Build Coastguard Worker }
1830*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_fulltile)1831*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_fulltile) {
1832*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1833*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1834*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1835*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1836*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1838*4bdc9457SAndroid Build Coastguard Worker }
1839*4bdc9457SAndroid Build Coastguard Worker }
1840*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_fulltile_with_input_offset)1841*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_fulltile_with_input_offset) {
1842*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; 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 .input_offset(5)
1848*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1849*4bdc9457SAndroid Build Coastguard Worker }
1850*4bdc9457SAndroid Build Coastguard Worker }
1851*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_fulltile_with_zero_index)1852*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_fulltile_with_zero_index) {
1853*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1854*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1855*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1856*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1857*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1858*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1859*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1860*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1861*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1862*4bdc9457SAndroid Build Coastguard Worker }
1863*4bdc9457SAndroid Build Coastguard Worker }
1864*4bdc9457SAndroid Build Coastguard Worker }
1865*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_fulltile_with_qmin)1866*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_fulltile_with_qmin) {
1867*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1868*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1869*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1870*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1871*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1872*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1873*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1874*4bdc9457SAndroid Build Coastguard Worker }
1875*4bdc9457SAndroid Build Coastguard Worker }
1876*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_fulltile_with_qmax)1877*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_fulltile_with_qmax) {
1878*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1879*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1880*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1881*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1882*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1883*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1884*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1885*4bdc9457SAndroid Build Coastguard Worker }
1886*4bdc9457SAndroid Build Coastguard Worker }
1887*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_subtile)1888*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_subtile) {
1889*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1890*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1891*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1892*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1893*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1894*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1895*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1896*4bdc9457SAndroid Build Coastguard Worker }
1897*4bdc9457SAndroid Build Coastguard Worker }
1898*4bdc9457SAndroid Build Coastguard Worker }
1899*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_subtile_with_input_offset)1900*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_subtile_with_input_offset) {
1901*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1902*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1903*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1904*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1905*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1906*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1907*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1908*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1909*4bdc9457SAndroid Build Coastguard Worker }
1910*4bdc9457SAndroid Build Coastguard Worker }
1911*4bdc9457SAndroid Build Coastguard Worker }
1912*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_twopass_subtile_with_zero)1913*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_twopass_subtile_with_zero) {
1914*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
1915*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
1916*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
1917*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1918*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1919*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1920*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1921*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
1922*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1923*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1924*4bdc9457SAndroid Build Coastguard Worker }
1925*4bdc9457SAndroid Build Coastguard Worker }
1926*4bdc9457SAndroid Build Coastguard Worker }
1927*4bdc9457SAndroid Build Coastguard Worker }
1928*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_fulltile)1929*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_fulltile) {
1930*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1931*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1932*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1933*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1934*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1935*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1936*4bdc9457SAndroid Build Coastguard Worker }
1937*4bdc9457SAndroid Build Coastguard Worker }
1938*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_fulltile_with_input_offset)1939*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_fulltile_with_input_offset) {
1940*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1941*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1942*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1943*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1944*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1945*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1946*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1947*4bdc9457SAndroid Build Coastguard Worker }
1948*4bdc9457SAndroid Build Coastguard Worker }
1949*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_fulltile_with_zero)1950*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_fulltile_with_zero) {
1951*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1952*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
1953*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1954*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1955*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1956*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1957*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
1958*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
1959*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1960*4bdc9457SAndroid Build Coastguard Worker }
1961*4bdc9457SAndroid Build Coastguard Worker }
1962*4bdc9457SAndroid Build Coastguard Worker }
1963*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_fulltile_with_qmin)1964*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_fulltile_with_qmin) {
1965*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1966*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1967*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1968*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1969*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1970*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1971*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1972*4bdc9457SAndroid Build Coastguard Worker }
1973*4bdc9457SAndroid Build Coastguard Worker }
1974*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_fulltile_with_qmax)1975*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_fulltile_with_qmax) {
1976*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
1977*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1978*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
1979*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1980*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1981*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1982*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1983*4bdc9457SAndroid Build Coastguard Worker }
1984*4bdc9457SAndroid Build Coastguard Worker }
1985*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_subtile)1986*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_subtile) {
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 = 5; channels < 8; channels++) {
1989*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
1990*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
1991*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
1992*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1993*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
1994*4bdc9457SAndroid Build Coastguard Worker }
1995*4bdc9457SAndroid Build Coastguard Worker }
1996*4bdc9457SAndroid Build Coastguard Worker }
1997*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_subtile_with_input_offset)1998*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_subtile_with_input_offset) {
1999*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2000*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2001*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2002*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2003*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2004*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2005*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2006*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2007*4bdc9457SAndroid Build Coastguard Worker }
2008*4bdc9457SAndroid Build Coastguard Worker }
2009*4bdc9457SAndroid Build Coastguard Worker }
2010*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_twopass_subtile_with_zero)2011*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_twopass_subtile_with_zero) {
2012*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2013*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2014*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2015*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2016*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2017*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2018*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2019*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2020*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2021*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2022*4bdc9457SAndroid Build Coastguard Worker }
2023*4bdc9457SAndroid Build Coastguard Worker }
2024*4bdc9457SAndroid Build Coastguard Worker }
2025*4bdc9457SAndroid Build Coastguard Worker }
2026*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_multipass)2027*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_multipass) {
2028*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
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(4)
2033*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2034*4bdc9457SAndroid Build Coastguard Worker }
2035*4bdc9457SAndroid Build Coastguard Worker }
2036*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_multipass_with_input_offset)2037*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_multipass_with_input_offset) {
2038*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2039*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2040*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2041*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2042*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2043*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2044*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2045*4bdc9457SAndroid Build Coastguard Worker }
2046*4bdc9457SAndroid Build Coastguard Worker }
2047*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_multipass_with_zero)2048*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_multipass_with_zero) {
2049*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2050*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2051*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2052*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2053*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2054*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2055*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2056*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2057*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2058*4bdc9457SAndroid Build Coastguard Worker }
2059*4bdc9457SAndroid Build Coastguard Worker }
2060*4bdc9457SAndroid Build Coastguard Worker }
2061*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_multipass_with_qmin)2062*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_multipass_with_qmin) {
2063*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2064*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2065*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2066*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2067*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2068*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2069*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2070*4bdc9457SAndroid Build Coastguard Worker }
2071*4bdc9457SAndroid Build Coastguard Worker }
2072*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_eq_4_multipass_with_qmax)2073*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_eq_4_multipass_with_qmax) {
2074*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2075*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2076*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2077*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2078*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2079*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2081*4bdc9457SAndroid Build Coastguard Worker }
2082*4bdc9457SAndroid Build Coastguard Worker }
2083*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_multipass)2084*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_multipass) {
2085*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2086*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2087*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2088*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2089*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2090*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2091*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2092*4bdc9457SAndroid Build Coastguard Worker }
2093*4bdc9457SAndroid Build Coastguard Worker }
2094*4bdc9457SAndroid Build Coastguard Worker }
2095*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_multipass_with_input_offset)2096*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_multipass_with_input_offset) {
2097*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2098*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
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(channels)
2103*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2105*4bdc9457SAndroid Build Coastguard Worker }
2106*4bdc9457SAndroid Build Coastguard Worker }
2107*4bdc9457SAndroid Build Coastguard Worker }
2108*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_multipass_with_zero)2109*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_multipass_with_zero) {
2110*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2111*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2112*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2113*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2114*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2115*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2116*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2117*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2118*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2119*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2120*4bdc9457SAndroid Build Coastguard Worker }
2121*4bdc9457SAndroid Build Coastguard Worker }
2122*4bdc9457SAndroid Build Coastguard Worker }
2123*4bdc9457SAndroid Build Coastguard Worker }
2124*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_multipass_with_qmin)2125*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_multipass_with_qmin) {
2126*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2127*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2128*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2129*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2130*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2131*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2132*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2133*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2134*4bdc9457SAndroid Build Coastguard Worker }
2135*4bdc9457SAndroid Build Coastguard Worker }
2136*4bdc9457SAndroid Build Coastguard Worker }
2137*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_div_4_multipass_with_qmax)2138*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_div_4_multipass_with_qmax) {
2139*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2140*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2141*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2142*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2143*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2144*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2145*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2146*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2147*4bdc9457SAndroid Build Coastguard Worker }
2148*4bdc9457SAndroid Build Coastguard Worker }
2149*4bdc9457SAndroid Build Coastguard Worker }
2150*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_multipass)2151*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_multipass) {
2152*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2153*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2154*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2155*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2156*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2157*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2158*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2159*4bdc9457SAndroid Build Coastguard Worker }
2160*4bdc9457SAndroid Build Coastguard Worker }
2161*4bdc9457SAndroid Build Coastguard Worker }
2162*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_multipass_with_input_offset)2163*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_multipass_with_input_offset) {
2164*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2165*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2166*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2167*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2168*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2169*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2170*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
2171*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2172*4bdc9457SAndroid Build Coastguard Worker }
2173*4bdc9457SAndroid Build Coastguard Worker }
2174*4bdc9457SAndroid Build Coastguard Worker }
2175*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_multipass_with_zero)2176*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_multipass_with_zero) {
2177*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2178*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2179*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2180*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2181*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2182*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2183*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2184*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
2185*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2186*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2187*4bdc9457SAndroid Build Coastguard Worker }
2188*4bdc9457SAndroid Build Coastguard Worker }
2189*4bdc9457SAndroid Build Coastguard Worker }
2190*4bdc9457SAndroid Build Coastguard Worker }
2191*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_multipass_with_qmin)2192*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_multipass_with_qmin) {
2193*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2194*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2195*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2196*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2197*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2198*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2199*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2200*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2201*4bdc9457SAndroid Build Coastguard Worker }
2202*4bdc9457SAndroid Build Coastguard Worker }
2203*4bdc9457SAndroid Build Coastguard Worker }
2204*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_lt_4_multipass_with_qmax)2205*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_lt_4_multipass_with_qmax) {
2206*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2207*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2208*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2209*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2210*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2211*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2212*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2214*4bdc9457SAndroid Build Coastguard Worker }
2215*4bdc9457SAndroid Build Coastguard Worker }
2216*4bdc9457SAndroid Build Coastguard Worker }
2217*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_multipass)2218*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_multipass) {
2219*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2220*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2221*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2222*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2223*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2224*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2225*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2226*4bdc9457SAndroid Build Coastguard Worker }
2227*4bdc9457SAndroid Build Coastguard Worker }
2228*4bdc9457SAndroid Build Coastguard Worker }
2229*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_multipass_with_input_offset)2230*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_multipass_with_input_offset) {
2231*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2232*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2233*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2234*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2235*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2236*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2237*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2238*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2239*4bdc9457SAndroid Build Coastguard Worker }
2240*4bdc9457SAndroid Build Coastguard Worker }
2241*4bdc9457SAndroid Build Coastguard Worker }
2242*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_multipass_with_zero)2243*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_multipass_with_zero) {
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 = 5; channels < 8; channels++) {
2246*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2247*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2248*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2249*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2250*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2251*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2252*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2254*4bdc9457SAndroid Build Coastguard Worker }
2255*4bdc9457SAndroid Build Coastguard Worker }
2256*4bdc9457SAndroid Build Coastguard Worker }
2257*4bdc9457SAndroid Build Coastguard Worker }
2258*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_multipass_with_qmin)2259*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_multipass_with_qmin) {
2260*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2261*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2262*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2263*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2264*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2265*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2266*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2267*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2268*4bdc9457SAndroid Build Coastguard Worker }
2269*4bdc9457SAndroid Build Coastguard Worker }
2270*4bdc9457SAndroid Build Coastguard Worker }
2271*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,channels_gt_4_multipass_with_qmax)2272*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, channels_gt_4_multipass_with_qmax) {
2273*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2274*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2275*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2276*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2277*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2278*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2279*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2280*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2281*4bdc9457SAndroid Build Coastguard Worker }
2282*4bdc9457SAndroid Build Coastguard Worker }
2283*4bdc9457SAndroid Build Coastguard Worker }
2284*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels)2285*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels) {
2286*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2287*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2288*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2289*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2290*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2291*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2292*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2293*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2294*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_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(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_input_offset)2300*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_input_offset) {
2301*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2302*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2303*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2304*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2305*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
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_offset(23)
2310*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_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(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_zero)2316*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_zero) {
2317*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2318*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2319*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2320*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2321*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2322*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2323*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2324*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2325*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2326*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
2327*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2328*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2329*4bdc9457SAndroid Build Coastguard Worker }
2330*4bdc9457SAndroid Build Coastguard Worker }
2331*4bdc9457SAndroid Build Coastguard Worker }
2332*4bdc9457SAndroid Build Coastguard Worker }
2333*4bdc9457SAndroid Build Coastguard Worker }
2334*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_qmin)2335*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_qmin) {
2336*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2337*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2338*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2339*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2340*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2341*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2342*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2343*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2344*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2345*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2346*4bdc9457SAndroid Build Coastguard Worker }
2347*4bdc9457SAndroid Build Coastguard Worker }
2348*4bdc9457SAndroid Build Coastguard Worker }
2349*4bdc9457SAndroid Build Coastguard Worker }
2350*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_qmax)2351*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_qmax) {
2352*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2353*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2354*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2355*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2356*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2357*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2358*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2359*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2360*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2361*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2362*4bdc9457SAndroid Build Coastguard Worker }
2363*4bdc9457SAndroid Build Coastguard Worker }
2364*4bdc9457SAndroid Build Coastguard Worker }
2365*4bdc9457SAndroid Build Coastguard Worker }
2366*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_output_stride)2367*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_output_stride) {
2368*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2369*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2370*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2371*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2372*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2373*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2374*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2375*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2376*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
2377*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2378*4bdc9457SAndroid Build Coastguard Worker }
2379*4bdc9457SAndroid Build Coastguard Worker }
2380*4bdc9457SAndroid Build Coastguard Worker }
2381*4bdc9457SAndroid Build Coastguard Worker }
2382*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4,few_output_pixels_with_step)2383*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_ARM_C4, few_output_pixels_with_step) {
2384*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
2385*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
2386*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
2387*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
2388*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2389*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
2390*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2391*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2392*4bdc9457SAndroid Build Coastguard Worker .step(step)
2393*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2394*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
2395*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
2396*4bdc9457SAndroid Build Coastguard Worker }
2397*4bdc9457SAndroid Build Coastguard Worker }
2398*4bdc9457SAndroid Build Coastguard Worker }
2399*4bdc9457SAndroid Build Coastguard Worker }
2400*4bdc9457SAndroid Build Coastguard Worker }
2401*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2402*4bdc9457SAndroid Build Coastguard Worker
2403*4bdc9457SAndroid Build Coastguard Worker
2404*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_fulltile)2405*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_fulltile) {
2406*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2407*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2408*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2409*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2410*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2411*4bdc9457SAndroid Build Coastguard Worker }
2412*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_fulltile_with_input_offset)2413*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_fulltile_with_input_offset) {
2414*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2415*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2416*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2417*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2418*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2419*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2420*4bdc9457SAndroid Build Coastguard Worker }
2421*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_fulltile_with_zero)2422*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_fulltile_with_zero) {
2423*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2424*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2425*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2426*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2427*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2428*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2429*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2430*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2431*4bdc9457SAndroid Build Coastguard Worker }
2432*4bdc9457SAndroid Build Coastguard Worker }
2433*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_fulltile_with_qmin)2434*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_fulltile_with_qmin) {
2435*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2436*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2437*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2438*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2439*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2441*4bdc9457SAndroid Build Coastguard Worker }
2442*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_fulltile_with_qmax)2443*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_fulltile_with_qmax) {
2444*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2445*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2446*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2447*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2448*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2450*4bdc9457SAndroid Build Coastguard Worker }
2451*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_subtile)2452*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_subtile) {
2453*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2454*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2455*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2456*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2457*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2459*4bdc9457SAndroid Build Coastguard Worker }
2460*4bdc9457SAndroid Build Coastguard Worker }
2461*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_subtile_with_input_offset)2462*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_subtile_with_input_offset) {
2463*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2464*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2465*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2466*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2467*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2468*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2469*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2470*4bdc9457SAndroid Build Coastguard Worker }
2471*4bdc9457SAndroid Build Coastguard Worker }
2472*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_twopass_subtile_with_zero)2473*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_twopass_subtile_with_zero) {
2474*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2475*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2476*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2477*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2478*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2479*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2480*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2481*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2482*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2483*4bdc9457SAndroid Build Coastguard Worker }
2484*4bdc9457SAndroid Build Coastguard Worker }
2485*4bdc9457SAndroid Build Coastguard Worker }
2486*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_fulltile)2487*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_fulltile) {
2488*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2489*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2490*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2491*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2492*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2493*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2494*4bdc9457SAndroid Build Coastguard Worker }
2495*4bdc9457SAndroid Build Coastguard Worker }
2496*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_fulltile_with_input_offset)2497*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_fulltile_with_input_offset) {
2498*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2499*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2500*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2501*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2502*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2503*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
2504*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2505*4bdc9457SAndroid Build Coastguard Worker }
2506*4bdc9457SAndroid Build Coastguard Worker }
2507*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_fulltile_with_zero)2508*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_fulltile_with_zero) {
2509*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2510*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2511*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2512*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2513*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2514*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2515*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
2516*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2517*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2518*4bdc9457SAndroid Build Coastguard Worker }
2519*4bdc9457SAndroid Build Coastguard Worker }
2520*4bdc9457SAndroid Build Coastguard Worker }
2521*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_fulltile_with_qmin)2522*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_fulltile_with_qmin) {
2523*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2524*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2525*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2526*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2527*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2528*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2529*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2530*4bdc9457SAndroid Build Coastguard Worker }
2531*4bdc9457SAndroid Build Coastguard Worker }
2532*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_fulltile_with_qmax)2533*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_fulltile_with_qmax) {
2534*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2535*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2536*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2537*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2538*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2539*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2540*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2541*4bdc9457SAndroid Build Coastguard Worker }
2542*4bdc9457SAndroid Build Coastguard Worker }
2543*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_subtile)2544*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_subtile) {
2545*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2546*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2547*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2548*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2549*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2550*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2552*4bdc9457SAndroid Build Coastguard Worker }
2553*4bdc9457SAndroid Build Coastguard Worker }
2554*4bdc9457SAndroid Build Coastguard Worker }
2555*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_subtile_with_input_offset)2556*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_subtile_with_input_offset) {
2557*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2558*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2559*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2560*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2561*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2562*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2563*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2564*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2565*4bdc9457SAndroid Build Coastguard Worker }
2566*4bdc9457SAndroid Build Coastguard Worker }
2567*4bdc9457SAndroid Build Coastguard Worker }
2568*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_twopass_subtile_with_zero)2569*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_twopass_subtile_with_zero) {
2570*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2571*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2572*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2573*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2574*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2575*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2576*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2577*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2578*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2579*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2580*4bdc9457SAndroid Build Coastguard Worker }
2581*4bdc9457SAndroid Build Coastguard Worker }
2582*4bdc9457SAndroid Build Coastguard Worker }
2583*4bdc9457SAndroid Build Coastguard Worker }
2584*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_fulltile)2585*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_fulltile) {
2586*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2587*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2588*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2589*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2590*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2591*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2592*4bdc9457SAndroid Build Coastguard Worker }
2593*4bdc9457SAndroid Build Coastguard Worker }
2594*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_fulltile_with_input_offset)2595*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_fulltile_with_input_offset) {
2596*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2597*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2598*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2599*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2600*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2601*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
2602*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2603*4bdc9457SAndroid Build Coastguard Worker }
2604*4bdc9457SAndroid Build Coastguard Worker }
2605*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_fulltile_with_zero_index)2606*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_fulltile_with_zero_index) {
2607*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2608*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2609*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2610*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2611*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2612*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2613*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
2614*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2615*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2616*4bdc9457SAndroid Build Coastguard Worker }
2617*4bdc9457SAndroid Build Coastguard Worker }
2618*4bdc9457SAndroid Build Coastguard Worker }
2619*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_fulltile_with_qmin)2620*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_fulltile_with_qmin) {
2621*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2622*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2623*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2624*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2625*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2626*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2627*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2628*4bdc9457SAndroid Build Coastguard Worker }
2629*4bdc9457SAndroid Build Coastguard Worker }
2630*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_fulltile_with_qmax)2631*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_fulltile_with_qmax) {
2632*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2633*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2634*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2635*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2636*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2637*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2638*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2639*4bdc9457SAndroid Build Coastguard Worker }
2640*4bdc9457SAndroid Build Coastguard Worker }
2641*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_subtile)2642*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_subtile) {
2643*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2644*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2645*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
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 .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2650*4bdc9457SAndroid Build Coastguard Worker }
2651*4bdc9457SAndroid Build Coastguard Worker }
2652*4bdc9457SAndroid Build Coastguard Worker }
2653*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_subtile_with_input_offset)2654*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_subtile_with_input_offset) {
2655*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2656*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2657*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2658*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2659*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2660*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2661*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
2662*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2663*4bdc9457SAndroid Build Coastguard Worker }
2664*4bdc9457SAndroid Build Coastguard Worker }
2665*4bdc9457SAndroid Build Coastguard Worker }
2666*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_twopass_subtile_with_zero)2667*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_twopass_subtile_with_zero) {
2668*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2669*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2670*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2671*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2672*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2673*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2674*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2675*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
2676*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2677*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2678*4bdc9457SAndroid Build Coastguard Worker }
2679*4bdc9457SAndroid Build Coastguard Worker }
2680*4bdc9457SAndroid Build Coastguard Worker }
2681*4bdc9457SAndroid Build Coastguard Worker }
2682*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_fulltile)2683*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_fulltile) {
2684*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2685*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2686*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2687*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2688*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2689*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2690*4bdc9457SAndroid Build Coastguard Worker }
2691*4bdc9457SAndroid Build Coastguard Worker }
2692*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_fulltile_with_input_offset)2693*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_fulltile_with_input_offset) {
2694*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2695*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2696*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2697*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2698*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2699*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2700*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2701*4bdc9457SAndroid Build Coastguard Worker }
2702*4bdc9457SAndroid Build Coastguard Worker }
2703*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_fulltile_with_zero)2704*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_fulltile_with_zero) {
2705*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2706*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
2707*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2708*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2709*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2710*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2711*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2712*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2714*4bdc9457SAndroid Build Coastguard Worker }
2715*4bdc9457SAndroid Build Coastguard Worker }
2716*4bdc9457SAndroid Build Coastguard Worker }
2717*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_fulltile_with_qmin)2718*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_fulltile_with_qmin) {
2719*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2720*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2721*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
2722*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2723*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2724*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2725*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2726*4bdc9457SAndroid Build Coastguard Worker }
2727*4bdc9457SAndroid Build Coastguard Worker }
2728*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_fulltile_with_qmax)2729*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_fulltile_with_qmax) {
2730*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
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(channels)
2735*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2736*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2737*4bdc9457SAndroid Build Coastguard Worker }
2738*4bdc9457SAndroid Build Coastguard Worker }
2739*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_subtile)2740*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_subtile) {
2741*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2742*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2743*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2744*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2745*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2746*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2747*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2748*4bdc9457SAndroid Build Coastguard Worker }
2749*4bdc9457SAndroid Build Coastguard Worker }
2750*4bdc9457SAndroid Build Coastguard Worker }
2751*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_subtile_with_input_offset)2752*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_subtile_with_input_offset) {
2753*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2754*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2755*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2756*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2757*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2758*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2759*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2760*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2761*4bdc9457SAndroid Build Coastguard Worker }
2762*4bdc9457SAndroid Build Coastguard Worker }
2763*4bdc9457SAndroid Build Coastguard Worker }
2764*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_twopass_subtile_with_zero)2765*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_twopass_subtile_with_zero) {
2766*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
2767*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2768*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2769*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2770*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2771*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2772*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2773*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2774*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2775*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2776*4bdc9457SAndroid Build Coastguard Worker }
2777*4bdc9457SAndroid Build Coastguard Worker }
2778*4bdc9457SAndroid Build Coastguard Worker }
2779*4bdc9457SAndroid Build Coastguard Worker }
2780*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_multipass)2781*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_multipass) {
2782*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2783*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2784*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2785*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2786*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2787*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2788*4bdc9457SAndroid Build Coastguard Worker }
2789*4bdc9457SAndroid Build Coastguard Worker }
2790*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_multipass_with_input_offset)2791*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_multipass_with_input_offset) {
2792*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2793*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2794*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2795*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2796*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2797*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2798*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2799*4bdc9457SAndroid Build Coastguard Worker }
2800*4bdc9457SAndroid Build Coastguard Worker }
2801*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_multipass_with_zero)2802*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_multipass_with_zero) {
2803*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2804*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2805*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2806*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2807*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2808*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2809*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
2810*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2811*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2812*4bdc9457SAndroid Build Coastguard Worker }
2813*4bdc9457SAndroid Build Coastguard Worker }
2814*4bdc9457SAndroid Build Coastguard Worker }
2815*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_multipass_with_qmin)2816*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_multipass_with_qmin) {
2817*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2818*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2819*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2820*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2821*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2822*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2823*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2824*4bdc9457SAndroid Build Coastguard Worker }
2825*4bdc9457SAndroid Build Coastguard Worker }
2826*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_eq_4_multipass_with_qmax)2827*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_eq_4_multipass_with_qmax) {
2828*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2829*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2830*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2831*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2832*4bdc9457SAndroid Build Coastguard Worker .channels(4)
2833*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2834*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2835*4bdc9457SAndroid Build Coastguard Worker }
2836*4bdc9457SAndroid Build Coastguard Worker }
2837*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_multipass)2838*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_multipass) {
2839*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2840*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2841*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2842*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2843*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2844*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2845*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2846*4bdc9457SAndroid Build Coastguard Worker }
2847*4bdc9457SAndroid Build Coastguard Worker }
2848*4bdc9457SAndroid Build Coastguard Worker }
2849*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_multipass_with_input_offset)2850*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_multipass_with_input_offset) {
2851*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2852*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2853*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2854*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2855*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2856*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2857*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2858*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2859*4bdc9457SAndroid Build Coastguard Worker }
2860*4bdc9457SAndroid Build Coastguard Worker }
2861*4bdc9457SAndroid Build Coastguard Worker }
2862*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_multipass_with_zero)2863*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_multipass_with_zero) {
2864*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2865*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2866*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2867*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2868*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2869*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2870*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2871*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
2872*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2873*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2874*4bdc9457SAndroid Build Coastguard Worker }
2875*4bdc9457SAndroid Build Coastguard Worker }
2876*4bdc9457SAndroid Build Coastguard Worker }
2877*4bdc9457SAndroid Build Coastguard Worker }
2878*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_multipass_with_qmin)2879*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_multipass_with_qmin) {
2880*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2881*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2882*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2883*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2884*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2885*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2886*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2888*4bdc9457SAndroid Build Coastguard Worker }
2889*4bdc9457SAndroid Build Coastguard Worker }
2890*4bdc9457SAndroid Build Coastguard Worker }
2891*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_div_4_multipass_with_qmax)2892*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_div_4_multipass_with_qmax) {
2893*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2894*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
2895*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2896*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2897*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2898*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2899*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2900*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2901*4bdc9457SAndroid Build Coastguard Worker }
2902*4bdc9457SAndroid Build Coastguard Worker }
2903*4bdc9457SAndroid Build Coastguard Worker }
2904*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_multipass)2905*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_multipass) {
2906*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2907*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2908*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2909*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2910*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2911*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2912*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2913*4bdc9457SAndroid Build Coastguard Worker }
2914*4bdc9457SAndroid Build Coastguard Worker }
2915*4bdc9457SAndroid Build Coastguard Worker }
2916*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_multipass_with_input_offset)2917*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_multipass_with_input_offset) {
2918*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2919*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2920*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2921*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2922*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2923*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2924*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
2925*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2926*4bdc9457SAndroid Build Coastguard Worker }
2927*4bdc9457SAndroid Build Coastguard Worker }
2928*4bdc9457SAndroid Build Coastguard Worker }
2929*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_multipass_with_zero)2930*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_multipass_with_zero) {
2931*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2932*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2933*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
2934*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2935*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2936*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2937*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2938*4bdc9457SAndroid Build Coastguard Worker .input_offset(4)
2939*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
2940*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2941*4bdc9457SAndroid Build Coastguard Worker }
2942*4bdc9457SAndroid Build Coastguard Worker }
2943*4bdc9457SAndroid Build Coastguard Worker }
2944*4bdc9457SAndroid Build Coastguard Worker }
2945*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_multipass_with_qmin)2946*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_multipass_with_qmin) {
2947*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2948*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2949*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2950*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2951*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2952*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2953*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2954*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2955*4bdc9457SAndroid Build Coastguard Worker }
2956*4bdc9457SAndroid Build Coastguard Worker }
2957*4bdc9457SAndroid Build Coastguard Worker }
2958*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_lt_4_multipass_with_qmax)2959*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_lt_4_multipass_with_qmax) {
2960*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2961*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
2962*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2963*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2964*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2965*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2966*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2967*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2968*4bdc9457SAndroid Build Coastguard Worker }
2969*4bdc9457SAndroid Build Coastguard Worker }
2970*4bdc9457SAndroid Build Coastguard Worker }
2971*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_multipass)2972*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_multipass) {
2973*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2974*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2975*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2976*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2977*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2978*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2979*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2980*4bdc9457SAndroid Build Coastguard Worker }
2981*4bdc9457SAndroid Build Coastguard Worker }
2982*4bdc9457SAndroid Build Coastguard Worker }
2983*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_multipass_with_input_offset)2984*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_multipass_with_input_offset) {
2985*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2986*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
2987*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
2988*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
2989*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
2990*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2991*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
2992*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
2993*4bdc9457SAndroid Build Coastguard Worker }
2994*4bdc9457SAndroid Build Coastguard Worker }
2995*4bdc9457SAndroid Build Coastguard Worker }
2996*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_multipass_with_zero)2997*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_multipass_with_zero) {
2998*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
2999*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
3000*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3001*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3002*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3003*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3004*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3005*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
3006*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3007*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3008*4bdc9457SAndroid Build Coastguard Worker }
3009*4bdc9457SAndroid Build Coastguard Worker }
3010*4bdc9457SAndroid Build Coastguard Worker }
3011*4bdc9457SAndroid Build Coastguard Worker }
3012*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_multipass_with_qmin)3013*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_multipass_with_qmin) {
3014*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3015*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
3016*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3017*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3018*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3019*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3020*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3021*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3022*4bdc9457SAndroid Build Coastguard Worker }
3023*4bdc9457SAndroid Build Coastguard Worker }
3024*4bdc9457SAndroid Build Coastguard Worker }
3025*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,channels_gt_4_multipass_with_qmax)3026*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, channels_gt_4_multipass_with_qmax) {
3027*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3028*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
3029*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3030*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3031*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3032*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3033*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3034*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3035*4bdc9457SAndroid Build Coastguard Worker }
3036*4bdc9457SAndroid Build Coastguard Worker }
3037*4bdc9457SAndroid Build Coastguard Worker }
3038*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels)3039*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels) {
3040*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3041*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3042*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3043*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3044*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3045*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3046*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3047*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3048*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3049*4bdc9457SAndroid Build Coastguard Worker }
3050*4bdc9457SAndroid Build Coastguard Worker }
3051*4bdc9457SAndroid Build Coastguard Worker }
3052*4bdc9457SAndroid Build Coastguard Worker }
3053*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_input_offset)3054*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_input_offset) {
3055*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3056*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3057*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3058*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3059*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3060*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3061*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3062*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3063*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
3064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3065*4bdc9457SAndroid Build Coastguard Worker }
3066*4bdc9457SAndroid Build Coastguard Worker }
3067*4bdc9457SAndroid Build Coastguard Worker }
3068*4bdc9457SAndroid Build Coastguard Worker }
3069*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_zero)3070*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_zero) {
3071*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3072*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3073*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3074*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3075*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3076*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3077*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3078*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3079*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3080*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
3081*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3082*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3083*4bdc9457SAndroid Build Coastguard Worker }
3084*4bdc9457SAndroid Build Coastguard Worker }
3085*4bdc9457SAndroid Build Coastguard Worker }
3086*4bdc9457SAndroid Build Coastguard Worker }
3087*4bdc9457SAndroid Build Coastguard Worker }
3088*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_qmin)3089*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_qmin) {
3090*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3091*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3092*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3093*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3094*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3095*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3096*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3097*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3098*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3099*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3100*4bdc9457SAndroid Build Coastguard Worker }
3101*4bdc9457SAndroid Build Coastguard Worker }
3102*4bdc9457SAndroid Build Coastguard Worker }
3103*4bdc9457SAndroid Build Coastguard Worker }
3104*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_qmax)3105*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_qmax) {
3106*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3107*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3108*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3109*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3110*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3111*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3112*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3113*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3114*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3115*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3116*4bdc9457SAndroid Build Coastguard Worker }
3117*4bdc9457SAndroid Build Coastguard Worker }
3118*4bdc9457SAndroid Build Coastguard Worker }
3119*4bdc9457SAndroid Build Coastguard Worker }
3120*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_output_stride)3121*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_output_stride) {
3122*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3123*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3124*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3125*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3126*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3127*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3128*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3129*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3130*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
3131*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3132*4bdc9457SAndroid Build Coastguard Worker }
3133*4bdc9457SAndroid Build Coastguard Worker }
3134*4bdc9457SAndroid Build Coastguard Worker }
3135*4bdc9457SAndroid Build Coastguard Worker }
3136*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4,few_output_pixels_with_step)3137*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASMSIMD_X86_C4, few_output_pixels_with_step) {
3138*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3139*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3140*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
3141*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
3142*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3143*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3144*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3145*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3146*4bdc9457SAndroid Build Coastguard Worker .step(step)
3147*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3148*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
3149*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
3150*4bdc9457SAndroid Build Coastguard Worker }
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 #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3156*4bdc9457SAndroid Build Coastguard Worker
3157*4bdc9457SAndroid Build Coastguard Worker
3158*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASM || XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_fulltile)3159*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_fulltile) {
3160*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3161*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3162*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3163*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3165*4bdc9457SAndroid Build Coastguard Worker }
3166*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_fulltile_with_input_offset)3167*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_fulltile_with_input_offset) {
3168*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3169*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3170*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3171*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3172*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3174*4bdc9457SAndroid Build Coastguard Worker }
3175*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_fulltile_with_zero)3176*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_fulltile_with_zero) {
3177*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
3178*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3179*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3180*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3181*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3182*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3183*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3184*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3185*4bdc9457SAndroid Build Coastguard Worker }
3186*4bdc9457SAndroid Build Coastguard Worker }
3187*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_fulltile_with_qmin)3188*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_fulltile_with_qmin) {
3189*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3190*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3191*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3192*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3193*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3194*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3195*4bdc9457SAndroid Build Coastguard Worker }
3196*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_fulltile_with_qmax)3197*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_fulltile_with_qmax) {
3198*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3199*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3200*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3201*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3202*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3203*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3204*4bdc9457SAndroid Build Coastguard Worker }
3205*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_subtile)3206*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_subtile) {
3207*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3208*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3209*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3210*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3211*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3212*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3213*4bdc9457SAndroid Build Coastguard Worker }
3214*4bdc9457SAndroid Build Coastguard Worker }
3215*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_subtile_with_input_offset)3216*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_subtile_with_input_offset) {
3217*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3218*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3219*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3220*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3221*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3222*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3223*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3224*4bdc9457SAndroid Build Coastguard Worker }
3225*4bdc9457SAndroid Build Coastguard Worker }
3226*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_twopass_subtile_with_zero)3227*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_twopass_subtile_with_zero) {
3228*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3229*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3230*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3231*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3232*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3233*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3234*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3235*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3236*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3237*4bdc9457SAndroid Build Coastguard Worker }
3238*4bdc9457SAndroid Build Coastguard Worker }
3239*4bdc9457SAndroid Build Coastguard Worker }
3240*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_fulltile)3241*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_fulltile) {
3242*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3243*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3244*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3245*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3246*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3247*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3248*4bdc9457SAndroid Build Coastguard Worker }
3249*4bdc9457SAndroid Build Coastguard Worker }
3250*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_fulltile_with_input_offset)3251*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_fulltile_with_input_offset) {
3252*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3253*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3254*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3255*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3256*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3257*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3258*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3259*4bdc9457SAndroid Build Coastguard Worker }
3260*4bdc9457SAndroid Build Coastguard Worker }
3261*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_fulltile_with_zero)3262*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_fulltile_with_zero) {
3263*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3264*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
3265*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3266*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3267*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3268*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3269*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3270*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3272*4bdc9457SAndroid Build Coastguard Worker }
3273*4bdc9457SAndroid Build Coastguard Worker }
3274*4bdc9457SAndroid Build Coastguard Worker }
3275*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_fulltile_with_qmin)3276*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_fulltile_with_qmin) {
3277*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3278*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3279*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3280*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3281*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3282*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3283*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3284*4bdc9457SAndroid Build Coastguard Worker }
3285*4bdc9457SAndroid Build Coastguard Worker }
3286*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_fulltile_with_qmax)3287*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_fulltile_with_qmax) {
3288*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3289*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3290*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3291*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3292*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3293*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3294*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3295*4bdc9457SAndroid Build Coastguard Worker }
3296*4bdc9457SAndroid Build Coastguard Worker }
3297*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_subtile)3298*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_subtile) {
3299*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3300*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3301*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3302*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3303*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3304*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3305*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3306*4bdc9457SAndroid Build Coastguard Worker }
3307*4bdc9457SAndroid Build Coastguard Worker }
3308*4bdc9457SAndroid Build Coastguard Worker }
3309*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_subtile_with_input_offset)3310*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_subtile_with_input_offset) {
3311*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3312*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3313*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3314*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3315*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3316*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3317*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3318*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3319*4bdc9457SAndroid Build Coastguard Worker }
3320*4bdc9457SAndroid Build Coastguard Worker }
3321*4bdc9457SAndroid Build Coastguard Worker }
3322*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_twopass_subtile_with_zero)3323*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_twopass_subtile_with_zero) {
3324*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3325*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3326*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3327*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3328*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3329*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3330*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3331*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3332*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3333*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3334*4bdc9457SAndroid Build Coastguard Worker }
3335*4bdc9457SAndroid Build Coastguard Worker }
3336*4bdc9457SAndroid Build Coastguard Worker }
3337*4bdc9457SAndroid Build Coastguard Worker }
3338*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_multipass)3339*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_multipass) {
3340*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3341*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3342*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3343*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3344*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3345*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3346*4bdc9457SAndroid Build Coastguard Worker }
3347*4bdc9457SAndroid Build Coastguard Worker }
3348*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_multipass_with_input_offset)3349*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_multipass_with_input_offset) {
3350*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3351*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3352*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3353*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3354*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3355*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3356*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3357*4bdc9457SAndroid Build Coastguard Worker }
3358*4bdc9457SAndroid Build Coastguard Worker }
3359*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_multipass_with_zero)3360*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_multipass_with_zero) {
3361*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3362*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3363*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3364*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3365*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3366*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3367*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3368*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3369*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3370*4bdc9457SAndroid Build Coastguard Worker }
3371*4bdc9457SAndroid Build Coastguard Worker }
3372*4bdc9457SAndroid Build Coastguard Worker }
3373*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_multipass_with_qmin)3374*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_multipass_with_qmin) {
3375*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3376*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3377*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3378*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3379*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3380*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3381*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3382*4bdc9457SAndroid Build Coastguard Worker }
3383*4bdc9457SAndroid Build Coastguard Worker }
3384*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_eq_1_multipass_with_qmax)3385*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_eq_1_multipass_with_qmax) {
3386*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3387*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3388*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3389*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3390*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3391*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3392*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3393*4bdc9457SAndroid Build Coastguard Worker }
3394*4bdc9457SAndroid Build Coastguard Worker }
3395*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_multipass)3396*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_multipass) {
3397*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3398*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3399*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3400*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3401*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3402*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3404*4bdc9457SAndroid Build Coastguard Worker }
3405*4bdc9457SAndroid Build Coastguard Worker }
3406*4bdc9457SAndroid Build Coastguard Worker }
3407*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_multipass_with_input_offset)3408*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_multipass_with_input_offset) {
3409*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3410*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3411*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3412*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3413*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3414*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3415*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3416*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3417*4bdc9457SAndroid Build Coastguard Worker }
3418*4bdc9457SAndroid Build Coastguard Worker }
3419*4bdc9457SAndroid Build Coastguard Worker }
3420*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_multipass_with_zero)3421*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_multipass_with_zero) {
3422*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3423*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3424*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3425*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3426*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3427*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3428*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3429*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3430*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3431*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3432*4bdc9457SAndroid Build Coastguard Worker }
3433*4bdc9457SAndroid Build Coastguard Worker }
3434*4bdc9457SAndroid Build Coastguard Worker }
3435*4bdc9457SAndroid Build Coastguard Worker }
3436*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_multipass_with_qmin)3437*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_multipass_with_qmin) {
3438*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3439*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3440*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3441*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3442*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3443*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3444*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3445*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3446*4bdc9457SAndroid Build Coastguard Worker }
3447*4bdc9457SAndroid Build Coastguard Worker }
3448*4bdc9457SAndroid Build Coastguard Worker }
3449*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,channels_gt_1_multipass_with_qmax)3450*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, channels_gt_1_multipass_with_qmax) {
3451*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3452*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3453*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3454*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3455*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3456*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3457*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3459*4bdc9457SAndroid Build Coastguard Worker }
3460*4bdc9457SAndroid Build Coastguard Worker }
3461*4bdc9457SAndroid Build Coastguard Worker }
3462*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels)3463*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels) {
3464*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3465*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3466*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3467*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3468*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3469*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3470*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3471*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3472*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3473*4bdc9457SAndroid Build Coastguard Worker }
3474*4bdc9457SAndroid Build Coastguard Worker }
3475*4bdc9457SAndroid Build Coastguard Worker }
3476*4bdc9457SAndroid Build Coastguard Worker }
3477*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_input_offset)3478*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_input_offset) {
3479*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3480*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3481*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3482*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3483*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3484*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3485*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3486*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3487*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
3488*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3489*4bdc9457SAndroid Build Coastguard Worker }
3490*4bdc9457SAndroid Build Coastguard Worker }
3491*4bdc9457SAndroid Build Coastguard Worker }
3492*4bdc9457SAndroid Build Coastguard Worker }
3493*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_zero)3494*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_zero) {
3495*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3496*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3497*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3498*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3499*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3500*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3501*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3502*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3503*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3504*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
3505*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3506*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3507*4bdc9457SAndroid Build Coastguard Worker }
3508*4bdc9457SAndroid Build Coastguard Worker }
3509*4bdc9457SAndroid Build Coastguard Worker }
3510*4bdc9457SAndroid Build Coastguard Worker }
3511*4bdc9457SAndroid Build Coastguard Worker }
3512*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_qmin)3513*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_qmin) {
3514*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3515*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3516*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3517*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3518*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3519*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3520*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3521*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3522*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3523*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3524*4bdc9457SAndroid Build Coastguard Worker }
3525*4bdc9457SAndroid Build Coastguard Worker }
3526*4bdc9457SAndroid Build Coastguard Worker }
3527*4bdc9457SAndroid Build Coastguard Worker }
3528*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_qmax)3529*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_qmax) {
3530*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3531*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3532*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3533*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3534*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3535*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3536*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3537*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3538*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3539*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3540*4bdc9457SAndroid Build Coastguard Worker }
3541*4bdc9457SAndroid Build Coastguard Worker }
3542*4bdc9457SAndroid Build Coastguard Worker }
3543*4bdc9457SAndroid Build Coastguard Worker }
3544*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_output_stride)3545*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_output_stride) {
3546*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3547*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3548*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3549*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3550*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3551*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3552*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3553*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3554*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
3555*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3556*4bdc9457SAndroid Build Coastguard Worker }
3557*4bdc9457SAndroid Build Coastguard Worker }
3558*4bdc9457SAndroid Build Coastguard Worker }
3559*4bdc9457SAndroid Build Coastguard Worker }
3560*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1,few_output_pixels_with_step)3561*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__WASM_C1, few_output_pixels_with_step) {
3562*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3563*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3564*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3565*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
3566*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3567*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3568*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3569*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3570*4bdc9457SAndroid Build Coastguard Worker .step(step)
3571*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3572*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
3573*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__wasm_c1, xnn_init_f32_minmax_scalar_params);
3574*4bdc9457SAndroid Build Coastguard Worker }
3575*4bdc9457SAndroid Build Coastguard Worker }
3576*4bdc9457SAndroid Build Coastguard Worker }
3577*4bdc9457SAndroid Build Coastguard Worker }
3578*4bdc9457SAndroid Build Coastguard Worker }
3579*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASM || XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3580*4bdc9457SAndroid Build Coastguard Worker
3581*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile)3582*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile) {
3583*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3584*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3585*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3586*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3587*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3588*4bdc9457SAndroid Build Coastguard Worker }
3589*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_input_offset)3590*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_input_offset) {
3591*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3592*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3593*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3594*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3595*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3597*4bdc9457SAndroid Build Coastguard Worker }
3598*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_zero)3599*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_zero) {
3600*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
3601*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3602*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3603*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3604*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3605*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3606*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3607*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3608*4bdc9457SAndroid Build Coastguard Worker }
3609*4bdc9457SAndroid Build Coastguard Worker }
3610*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_qmin)3611*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_qmin) {
3612*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3613*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3614*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3615*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3616*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3617*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3618*4bdc9457SAndroid Build Coastguard Worker }
3619*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_fulltile_with_qmax)3620*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_fulltile_with_qmax) {
3621*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3622*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3623*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3624*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3625*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3626*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3627*4bdc9457SAndroid Build Coastguard Worker }
3628*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile)3629*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile) {
3630*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3631*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3632*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3633*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3634*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3635*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3636*4bdc9457SAndroid Build Coastguard Worker }
3637*4bdc9457SAndroid Build Coastguard Worker }
3638*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile_with_input_offset)3639*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile_with_input_offset) {
3640*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3641*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3642*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3643*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3644*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3645*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3647*4bdc9457SAndroid Build Coastguard Worker }
3648*4bdc9457SAndroid Build Coastguard Worker }
3649*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_twopass_subtile_with_zero)3650*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_twopass_subtile_with_zero) {
3651*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3652*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3653*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3654*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3655*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3656*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3657*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3658*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3659*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3660*4bdc9457SAndroid Build Coastguard Worker }
3661*4bdc9457SAndroid Build Coastguard Worker }
3662*4bdc9457SAndroid Build Coastguard Worker }
3663*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile)3664*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile) {
3665*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3666*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3667*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3668*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3669*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3670*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3671*4bdc9457SAndroid Build Coastguard Worker }
3672*4bdc9457SAndroid Build Coastguard Worker }
3673*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_input_offset)3674*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_input_offset) {
3675*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3676*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3677*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3678*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3679*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3680*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3681*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3682*4bdc9457SAndroid Build Coastguard Worker }
3683*4bdc9457SAndroid Build Coastguard Worker }
3684*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_zero)3685*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_zero) {
3686*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3687*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 17; zero_index++) {
3688*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3689*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3690*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3691*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3692*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3693*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3694*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3695*4bdc9457SAndroid Build Coastguard Worker }
3696*4bdc9457SAndroid Build Coastguard Worker }
3697*4bdc9457SAndroid Build Coastguard Worker }
3698*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_qmin)3699*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_qmin) {
3700*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3701*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3702*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3703*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3704*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3705*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3706*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3707*4bdc9457SAndroid Build Coastguard Worker }
3708*4bdc9457SAndroid Build Coastguard Worker }
3709*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_fulltile_with_qmax)3710*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_fulltile_with_qmax) {
3711*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3712*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3713*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(17)
3714*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3715*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3716*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3717*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3718*4bdc9457SAndroid Build Coastguard Worker }
3719*4bdc9457SAndroid Build Coastguard Worker }
3720*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile)3721*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile) {
3722*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3723*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3724*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3725*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3726*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3727*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3729*4bdc9457SAndroid Build Coastguard Worker }
3730*4bdc9457SAndroid Build Coastguard Worker }
3731*4bdc9457SAndroid Build Coastguard Worker }
3732*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile_with_input_offset)3733*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile_with_input_offset) {
3734*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3735*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3736*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3737*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3738*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3739*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3740*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3741*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3742*4bdc9457SAndroid Build Coastguard Worker }
3743*4bdc9457SAndroid Build Coastguard Worker }
3744*4bdc9457SAndroid Build Coastguard Worker }
3745*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_twopass_subtile_with_zero)3746*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_twopass_subtile_with_zero) {
3747*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 10; pooling_elements < 17; pooling_elements++) {
3748*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3749*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3750*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3751*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3752*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3753*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3754*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3755*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3756*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3757*4bdc9457SAndroid Build Coastguard Worker }
3758*4bdc9457SAndroid Build Coastguard Worker }
3759*4bdc9457SAndroid Build Coastguard Worker }
3760*4bdc9457SAndroid Build Coastguard Worker }
3761*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass)3762*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass) {
3763*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3764*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3765*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3766*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3767*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3769*4bdc9457SAndroid Build Coastguard Worker }
3770*4bdc9457SAndroid Build Coastguard Worker }
3771*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_input_offset)3772*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_input_offset) {
3773*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3774*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3775*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3776*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3777*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3778*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3779*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3780*4bdc9457SAndroid Build Coastguard Worker }
3781*4bdc9457SAndroid Build Coastguard Worker }
3782*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_zero)3783*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_zero) {
3784*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3785*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3786*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3787*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3788*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3789*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3790*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3791*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3792*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3793*4bdc9457SAndroid Build Coastguard Worker }
3794*4bdc9457SAndroid Build Coastguard Worker }
3795*4bdc9457SAndroid Build Coastguard Worker }
3796*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_qmin)3797*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_qmin) {
3798*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3799*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3800*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3801*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3802*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3803*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3804*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3805*4bdc9457SAndroid Build Coastguard Worker }
3806*4bdc9457SAndroid Build Coastguard Worker }
3807*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_eq_1_multipass_with_qmax)3808*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_eq_1_multipass_with_qmax) {
3809*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3810*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3811*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3812*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3813*4bdc9457SAndroid Build Coastguard Worker .channels(1)
3814*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3815*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3816*4bdc9457SAndroid Build Coastguard Worker }
3817*4bdc9457SAndroid Build Coastguard Worker }
3818*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass)3819*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass) {
3820*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3821*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3822*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3823*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3824*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3825*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3826*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3827*4bdc9457SAndroid Build Coastguard Worker }
3828*4bdc9457SAndroid Build Coastguard Worker }
3829*4bdc9457SAndroid Build Coastguard Worker }
3830*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_input_offset)3831*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_input_offset) {
3832*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3833*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3834*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3835*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3836*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3837*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3838*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3839*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3840*4bdc9457SAndroid Build Coastguard Worker }
3841*4bdc9457SAndroid Build Coastguard Worker }
3842*4bdc9457SAndroid Build Coastguard Worker }
3843*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_zero)3844*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_zero) {
3845*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3846*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3847*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3848*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3849*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3850*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3851*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3852*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
3853*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3855*4bdc9457SAndroid Build Coastguard Worker }
3856*4bdc9457SAndroid Build Coastguard Worker }
3857*4bdc9457SAndroid Build Coastguard Worker }
3858*4bdc9457SAndroid Build Coastguard Worker }
3859*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_qmin)3860*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_qmin) {
3861*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3862*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3863*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3864*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3865*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3866*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3867*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3868*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3869*4bdc9457SAndroid Build Coastguard Worker }
3870*4bdc9457SAndroid Build Coastguard Worker }
3871*4bdc9457SAndroid Build Coastguard Worker }
3872*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,channels_gt_1_multipass_with_qmax)3873*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, channels_gt_1_multipass_with_qmax) {
3874*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 18; pooling_elements <= 33; pooling_elements += 3) {
3875*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
3876*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3877*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3878*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3879*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3880*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3881*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3882*4bdc9457SAndroid Build Coastguard Worker }
3883*4bdc9457SAndroid Build Coastguard Worker }
3884*4bdc9457SAndroid Build Coastguard Worker }
3885*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels)3886*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels) {
3887*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3888*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3889*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3890*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3891*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3892*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3893*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3894*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3895*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3896*4bdc9457SAndroid Build Coastguard Worker }
3897*4bdc9457SAndroid Build Coastguard Worker }
3898*4bdc9457SAndroid Build Coastguard Worker }
3899*4bdc9457SAndroid Build Coastguard Worker }
3900*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_input_offset)3901*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_input_offset) {
3902*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3903*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3904*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3905*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3906*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3907*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3908*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3909*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3910*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
3911*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3912*4bdc9457SAndroid Build Coastguard Worker }
3913*4bdc9457SAndroid Build Coastguard Worker }
3914*4bdc9457SAndroid Build Coastguard Worker }
3915*4bdc9457SAndroid Build Coastguard Worker }
3916*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_zero)3917*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_zero) {
3918*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3919*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3920*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3921*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
3922*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3923*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3924*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3925*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3926*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3927*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
3928*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
3929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3930*4bdc9457SAndroid Build Coastguard Worker }
3931*4bdc9457SAndroid Build Coastguard Worker }
3932*4bdc9457SAndroid Build Coastguard Worker }
3933*4bdc9457SAndroid Build Coastguard Worker }
3934*4bdc9457SAndroid Build Coastguard Worker }
3935*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_qmin)3936*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_qmin) {
3937*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3938*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3939*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3940*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3941*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3942*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3943*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3944*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3945*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3946*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3947*4bdc9457SAndroid Build Coastguard Worker }
3948*4bdc9457SAndroid Build Coastguard Worker }
3949*4bdc9457SAndroid Build Coastguard Worker }
3950*4bdc9457SAndroid Build Coastguard Worker }
3951*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_qmax)3952*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_qmax) {
3953*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3954*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3955*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3956*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3957*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3958*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3959*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3960*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3961*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3962*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3963*4bdc9457SAndroid Build Coastguard Worker }
3964*4bdc9457SAndroid Build Coastguard Worker }
3965*4bdc9457SAndroid Build Coastguard Worker }
3966*4bdc9457SAndroid Build Coastguard Worker }
3967*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_output_stride)3968*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_output_stride) {
3969*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3970*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3971*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3972*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3973*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3974*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3975*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3976*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3977*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
3978*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3979*4bdc9457SAndroid Build Coastguard Worker }
3980*4bdc9457SAndroid Build Coastguard Worker }
3981*4bdc9457SAndroid Build Coastguard Worker }
3982*4bdc9457SAndroid Build Coastguard Worker }
3983*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1,few_output_pixels_with_step)3984*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9P8X__SCALAR_C1, few_output_pixels_with_step) {
3985*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
3986*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{10, 16, 18}}) {
3987*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
3988*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
3989*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
3990*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
3991*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
3992*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 8)
3993*4bdc9457SAndroid Build Coastguard Worker .step(step)
3994*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3995*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
3996*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9p8x__scalar_c1, xnn_init_f32_minmax_scalar_params);
3997*4bdc9457SAndroid Build Coastguard Worker }
3998*4bdc9457SAndroid Build Coastguard Worker }
3999*4bdc9457SAndroid Build Coastguard Worker }
4000*4bdc9457SAndroid Build Coastguard Worker }
4001*4bdc9457SAndroid Build Coastguard Worker }
4002*4bdc9457SAndroid Build Coastguard Worker
4003*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_fulltile)4004*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_fulltile) {
4005*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4006*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4007*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4008*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4009*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4010*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4011*4bdc9457SAndroid Build Coastguard Worker }
4012*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_fulltile_with_input_offset)4013*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_fulltile_with_input_offset) {
4014*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4015*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4016*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4017*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4018*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4019*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4020*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4021*4bdc9457SAndroid Build Coastguard Worker }
4022*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_fulltile_with_zero)4023*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_fulltile_with_zero) {
4024*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4025*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4026*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4027*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4028*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4029*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4030*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4031*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4032*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4033*4bdc9457SAndroid Build Coastguard Worker }
4034*4bdc9457SAndroid Build Coastguard Worker }
4035*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_fulltile_with_qmin)4036*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_fulltile_with_qmin) {
4037*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4038*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4039*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4040*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4041*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4042*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4043*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4044*4bdc9457SAndroid Build Coastguard Worker }
4045*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_fulltile_with_qmax)4046*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_fulltile_with_qmax) {
4047*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4048*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4049*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4050*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4051*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4052*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4053*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4054*4bdc9457SAndroid Build Coastguard Worker }
4055*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_subtile)4056*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_subtile) {
4057*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4058*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4059*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4060*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4061*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4062*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4063*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4064*4bdc9457SAndroid Build Coastguard Worker }
4065*4bdc9457SAndroid Build Coastguard Worker }
4066*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_subtile_with_input_offset)4067*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_subtile_with_input_offset) {
4068*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4069*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4070*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4071*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4072*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4073*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4074*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4075*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4076*4bdc9457SAndroid Build Coastguard Worker }
4077*4bdc9457SAndroid Build Coastguard Worker }
4078*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_eq_4_unipass_subtile_with_zero)4079*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_eq_4_unipass_subtile_with_zero) {
4080*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4081*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4082*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4083*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4084*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4085*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4086*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4087*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4088*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4089*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4090*4bdc9457SAndroid Build Coastguard Worker }
4091*4bdc9457SAndroid Build Coastguard Worker }
4092*4bdc9457SAndroid Build Coastguard Worker }
4093*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_fulltile)4094*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_fulltile) {
4095*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4096*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4097*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4098*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4099*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4100*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4101*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4102*4bdc9457SAndroid Build Coastguard Worker }
4103*4bdc9457SAndroid Build Coastguard Worker }
4104*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_fulltile_with_input_offset)4105*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_fulltile_with_input_offset) {
4106*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4107*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4108*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4109*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4110*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4111*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4112*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
4113*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4114*4bdc9457SAndroid Build Coastguard Worker }
4115*4bdc9457SAndroid Build Coastguard Worker }
4116*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_fulltile_with_zero)4117*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_fulltile_with_zero) {
4118*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4119*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4120*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4121*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4122*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4123*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4124*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4125*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
4126*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4127*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4128*4bdc9457SAndroid Build Coastguard Worker }
4129*4bdc9457SAndroid Build Coastguard Worker }
4130*4bdc9457SAndroid Build Coastguard Worker }
4131*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_fulltile_with_qmin)4132*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_fulltile_with_qmin) {
4133*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4134*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4135*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4136*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4137*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4138*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4139*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4140*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4141*4bdc9457SAndroid Build Coastguard Worker }
4142*4bdc9457SAndroid Build Coastguard Worker }
4143*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_fulltile_with_qmax)4144*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_fulltile_with_qmax) {
4145*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4146*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4147*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4148*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4149*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4150*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4151*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4152*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4153*4bdc9457SAndroid Build Coastguard Worker }
4154*4bdc9457SAndroid Build Coastguard Worker }
4155*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_subtile)4156*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_subtile) {
4157*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4158*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4159*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4160*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4161*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4162*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4163*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4165*4bdc9457SAndroid Build Coastguard Worker }
4166*4bdc9457SAndroid Build Coastguard Worker }
4167*4bdc9457SAndroid Build Coastguard Worker }
4168*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_subtile_with_input_offset)4169*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_subtile_with_input_offset) {
4170*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4171*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4172*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4173*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
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 .input_offset(37)
4178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4179*4bdc9457SAndroid Build Coastguard Worker }
4180*4bdc9457SAndroid Build Coastguard Worker }
4181*4bdc9457SAndroid Build Coastguard Worker }
4182*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_div_4_unipass_subtile_with_zero)4183*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_div_4_unipass_subtile_with_zero) {
4184*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4185*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4186*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4187*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4188*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4189*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4190*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4191*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4192*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
4193*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4194*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4195*4bdc9457SAndroid Build Coastguard Worker }
4196*4bdc9457SAndroid Build Coastguard Worker }
4197*4bdc9457SAndroid Build Coastguard Worker }
4198*4bdc9457SAndroid Build Coastguard Worker }
4199*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_fulltile)4200*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_fulltile) {
4201*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4202*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4203*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4204*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4205*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4206*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4207*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4208*4bdc9457SAndroid Build Coastguard Worker }
4209*4bdc9457SAndroid Build Coastguard Worker }
4210*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_fulltile_with_input_offset)4211*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_fulltile_with_input_offset) {
4212*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4213*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4214*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4215*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4216*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4217*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4218*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4219*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4220*4bdc9457SAndroid Build Coastguard Worker }
4221*4bdc9457SAndroid Build Coastguard Worker }
4222*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_fulltile_with_zero)4223*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_fulltile_with_zero) {
4224*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4225*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4226*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4227*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4228*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4229*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4230*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4231*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4232*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4233*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4234*4bdc9457SAndroid Build Coastguard Worker }
4235*4bdc9457SAndroid Build Coastguard Worker }
4236*4bdc9457SAndroid Build Coastguard Worker }
4237*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_fulltile_with_qmin)4238*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_fulltile_with_qmin) {
4239*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4240*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4241*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4242*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4243*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4244*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4245*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4246*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4247*4bdc9457SAndroid Build Coastguard Worker }
4248*4bdc9457SAndroid Build Coastguard Worker }
4249*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_fulltile_with_qmax)4250*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_fulltile_with_qmax) {
4251*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4252*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4253*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4254*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4255*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4256*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4257*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4258*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4259*4bdc9457SAndroid Build Coastguard Worker }
4260*4bdc9457SAndroid Build Coastguard Worker }
4261*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_subtile)4262*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_subtile) {
4263*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4264*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4265*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4266*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4267*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4268*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4269*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4270*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4271*4bdc9457SAndroid Build Coastguard Worker }
4272*4bdc9457SAndroid Build Coastguard Worker }
4273*4bdc9457SAndroid Build Coastguard Worker }
4274*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_subtile_with_input_offset)4275*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_subtile_with_input_offset) {
4276*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4277*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4278*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4279*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4280*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4281*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4282*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4283*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4284*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4285*4bdc9457SAndroid Build Coastguard Worker }
4286*4bdc9457SAndroid Build Coastguard Worker }
4287*4bdc9457SAndroid Build Coastguard Worker }
4288*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_lt_4_unipass_subtile_with_zero)4289*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_lt_4_unipass_subtile_with_zero) {
4290*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4291*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4292*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4293*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4294*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4295*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4296*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4297*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4298*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4299*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4300*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4301*4bdc9457SAndroid Build Coastguard Worker }
4302*4bdc9457SAndroid Build Coastguard Worker }
4303*4bdc9457SAndroid Build Coastguard Worker }
4304*4bdc9457SAndroid Build Coastguard Worker }
4305*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_fulltile)4306*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_fulltile) {
4307*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4308*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4309*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4310*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4311*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4312*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4313*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4314*4bdc9457SAndroid Build Coastguard Worker }
4315*4bdc9457SAndroid Build Coastguard Worker }
4316*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_fulltile_with_input_offset)4317*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_fulltile_with_input_offset) {
4318*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4319*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4320*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4321*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4322*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4323*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4324*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4325*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4326*4bdc9457SAndroid Build Coastguard Worker }
4327*4bdc9457SAndroid Build Coastguard Worker }
4328*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_fulltile_with_zero)4329*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_fulltile_with_zero) {
4330*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4331*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4332*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4333*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4334*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4335*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4336*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4337*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4338*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4339*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4340*4bdc9457SAndroid Build Coastguard Worker }
4341*4bdc9457SAndroid Build Coastguard Worker }
4342*4bdc9457SAndroid Build Coastguard Worker }
4343*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_fulltile_with_qmin)4344*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_fulltile_with_qmin) {
4345*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4346*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4347*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4348*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4349*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4350*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4351*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4352*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4353*4bdc9457SAndroid Build Coastguard Worker }
4354*4bdc9457SAndroid Build Coastguard Worker }
4355*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_fulltile_with_qmax)4356*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_fulltile_with_qmax) {
4357*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4358*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4359*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4360*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4361*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4362*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4363*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4364*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4365*4bdc9457SAndroid Build Coastguard Worker }
4366*4bdc9457SAndroid Build Coastguard Worker }
4367*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_subtile)4368*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_subtile) {
4369*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4370*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4371*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4372*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4373*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4374*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4375*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4376*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4377*4bdc9457SAndroid Build Coastguard Worker }
4378*4bdc9457SAndroid Build Coastguard Worker }
4379*4bdc9457SAndroid Build Coastguard Worker }
4380*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_subtile_with_input_offset)4381*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_subtile_with_input_offset) {
4382*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4383*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4384*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4385*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4386*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4387*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4388*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4389*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4390*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4391*4bdc9457SAndroid Build Coastguard Worker }
4392*4bdc9457SAndroid Build Coastguard Worker }
4393*4bdc9457SAndroid Build Coastguard Worker }
4394*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,channels_gt_4_unipass_subtile_with_zero)4395*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, channels_gt_4_unipass_subtile_with_zero) {
4396*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4397*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4398*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4399*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4400*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4401*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4402*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4403*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4404*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4405*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4406*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4407*4bdc9457SAndroid Build Coastguard Worker }
4408*4bdc9457SAndroid Build Coastguard Worker }
4409*4bdc9457SAndroid Build Coastguard Worker }
4410*4bdc9457SAndroid Build Coastguard Worker }
4411*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels)4412*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels) {
4413*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4414*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4415*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4416*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4417*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4418*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4419*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4420*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4421*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4422*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4423*4bdc9457SAndroid Build Coastguard Worker }
4424*4bdc9457SAndroid Build Coastguard Worker }
4425*4bdc9457SAndroid Build Coastguard Worker }
4426*4bdc9457SAndroid Build Coastguard Worker }
4427*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_input_offset)4428*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_input_offset) {
4429*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4430*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4431*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4432*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4433*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4434*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4435*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4436*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4437*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4438*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
4439*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4440*4bdc9457SAndroid Build Coastguard Worker }
4441*4bdc9457SAndroid Build Coastguard Worker }
4442*4bdc9457SAndroid Build Coastguard Worker }
4443*4bdc9457SAndroid Build Coastguard Worker }
4444*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_zero)4445*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_zero) {
4446*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4447*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4448*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4449*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4450*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4451*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4452*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4453*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4454*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4455*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4456*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
4457*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4459*4bdc9457SAndroid Build Coastguard Worker }
4460*4bdc9457SAndroid Build Coastguard Worker }
4461*4bdc9457SAndroid Build Coastguard Worker }
4462*4bdc9457SAndroid Build Coastguard Worker }
4463*4bdc9457SAndroid Build Coastguard Worker }
4464*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_qmin)4465*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_qmin) {
4466*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4467*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4468*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4469*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4470*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4471*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4472*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4473*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4474*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4475*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4476*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4477*4bdc9457SAndroid Build Coastguard Worker }
4478*4bdc9457SAndroid Build Coastguard Worker }
4479*4bdc9457SAndroid Build Coastguard Worker }
4480*4bdc9457SAndroid Build Coastguard Worker }
4481*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_qmax)4482*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_qmax) {
4483*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4484*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4485*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4486*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4487*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4488*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4489*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4490*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4491*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4492*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4493*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4494*4bdc9457SAndroid Build Coastguard Worker }
4495*4bdc9457SAndroid Build Coastguard Worker }
4496*4bdc9457SAndroid Build Coastguard Worker }
4497*4bdc9457SAndroid Build Coastguard Worker }
4498*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_output_stride)4499*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_output_stride) {
4500*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4501*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4502*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4503*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4504*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4505*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4506*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4507*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4508*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4509*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
4510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4511*4bdc9457SAndroid Build Coastguard Worker }
4512*4bdc9457SAndroid Build Coastguard Worker }
4513*4bdc9457SAndroid Build Coastguard Worker }
4514*4bdc9457SAndroid Build Coastguard Worker }
4515*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4,few_output_pixels_with_step)4516*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__NEON_C4, few_output_pixels_with_step) {
4517*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4518*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4519*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4520*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4521*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
4522*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4523*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4524*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4525*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4526*4bdc9457SAndroid Build Coastguard Worker .step(step)
4527*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4528*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
4529*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__neon_c4, xnn_init_f32_minmax_scalar_params);
4530*4bdc9457SAndroid Build Coastguard Worker }
4531*4bdc9457SAndroid Build Coastguard Worker }
4532*4bdc9457SAndroid Build Coastguard Worker }
4533*4bdc9457SAndroid Build Coastguard Worker }
4534*4bdc9457SAndroid Build Coastguard Worker }
4535*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4536*4bdc9457SAndroid Build Coastguard Worker
4537*4bdc9457SAndroid Build Coastguard Worker
4538*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_fulltile)4539*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_fulltile) {
4540*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4541*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4542*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4543*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4544*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4545*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4546*4bdc9457SAndroid Build Coastguard Worker }
4547*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_fulltile_with_input_offset)4548*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_fulltile_with_input_offset) {
4549*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4550*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4551*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4552*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4553*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4554*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4555*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4556*4bdc9457SAndroid Build Coastguard Worker }
4557*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_fulltile_with_zero)4558*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_fulltile_with_zero) {
4559*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4560*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4561*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4562*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4563*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4564*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4565*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4566*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4567*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4568*4bdc9457SAndroid Build Coastguard Worker }
4569*4bdc9457SAndroid Build Coastguard Worker }
4570*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_fulltile_with_qmin)4571*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_fulltile_with_qmin) {
4572*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
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(4)
4577*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4579*4bdc9457SAndroid Build Coastguard Worker }
4580*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_fulltile_with_qmax)4581*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_fulltile_with_qmax) {
4582*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4583*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4584*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4585*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4586*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4587*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4588*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4589*4bdc9457SAndroid Build Coastguard Worker }
4590*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_subtile)4591*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_subtile) {
4592*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4593*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4594*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4595*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4596*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4597*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4598*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4599*4bdc9457SAndroid Build Coastguard Worker }
4600*4bdc9457SAndroid Build Coastguard Worker }
4601*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_subtile_with_input_offset)4602*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_subtile_with_input_offset) {
4603*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4604*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4605*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4606*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4607*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4608*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4609*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4610*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4611*4bdc9457SAndroid Build Coastguard Worker }
4612*4bdc9457SAndroid Build Coastguard Worker }
4613*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_eq_4_unipass_subtile_with_zero)4614*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_eq_4_unipass_subtile_with_zero) {
4615*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4616*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4617*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4618*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4619*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4620*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4621*4bdc9457SAndroid Build Coastguard Worker .channels(4)
4622*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
4623*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4624*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4625*4bdc9457SAndroid Build Coastguard Worker }
4626*4bdc9457SAndroid Build Coastguard Worker }
4627*4bdc9457SAndroid Build Coastguard Worker }
4628*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_fulltile)4629*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_fulltile) {
4630*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4631*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4632*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4633*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4634*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4635*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4636*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4637*4bdc9457SAndroid Build Coastguard Worker }
4638*4bdc9457SAndroid Build Coastguard Worker }
4639*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_fulltile_with_input_offset)4640*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_fulltile_with_input_offset) {
4641*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4642*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
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 .input_offset(37)
4648*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4649*4bdc9457SAndroid Build Coastguard Worker }
4650*4bdc9457SAndroid Build Coastguard Worker }
4651*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_fulltile_with_zero)4652*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_fulltile_with_zero) {
4653*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4654*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4655*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
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 .input_offset(37)
4661*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4662*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4663*4bdc9457SAndroid Build Coastguard Worker }
4664*4bdc9457SAndroid Build Coastguard Worker }
4665*4bdc9457SAndroid Build Coastguard Worker }
4666*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_fulltile_with_qmin)4667*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_fulltile_with_qmin) {
4668*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4669*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4670*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4671*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4672*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4673*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4674*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4675*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4676*4bdc9457SAndroid Build Coastguard Worker }
4677*4bdc9457SAndroid Build Coastguard Worker }
4678*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_fulltile_with_qmax)4679*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_fulltile_with_qmax) {
4680*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4681*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4682*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4683*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4684*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4685*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4686*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4687*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4688*4bdc9457SAndroid Build Coastguard Worker }
4689*4bdc9457SAndroid Build Coastguard Worker }
4690*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_subtile)4691*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_subtile) {
4692*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4693*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4694*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4695*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4696*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4697*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4698*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4699*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4700*4bdc9457SAndroid Build Coastguard Worker }
4701*4bdc9457SAndroid Build Coastguard Worker }
4702*4bdc9457SAndroid Build Coastguard Worker }
4703*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_subtile_with_input_offset)4704*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_subtile_with_input_offset) {
4705*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
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 = 8; channels < 32; channels += 4) {
4708*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4709*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4710*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4711*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4712*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
4713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4714*4bdc9457SAndroid Build Coastguard Worker }
4715*4bdc9457SAndroid Build Coastguard Worker }
4716*4bdc9457SAndroid Build Coastguard Worker }
4717*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_div_4_unipass_subtile_with_zero)4718*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_div_4_unipass_subtile_with_zero) {
4719*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4720*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4721*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
4722*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4723*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4724*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4725*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4726*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4727*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
4728*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4729*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4730*4bdc9457SAndroid Build Coastguard Worker }
4731*4bdc9457SAndroid Build Coastguard Worker }
4732*4bdc9457SAndroid Build Coastguard Worker }
4733*4bdc9457SAndroid Build Coastguard Worker }
4734*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_fulltile)4735*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_fulltile) {
4736*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4737*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4738*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4739*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4740*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4741*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4742*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4743*4bdc9457SAndroid Build Coastguard Worker }
4744*4bdc9457SAndroid Build Coastguard Worker }
4745*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_fulltile_with_input_offset)4746*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_fulltile_with_input_offset) {
4747*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4748*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4749*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4750*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4751*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4752*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4753*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4754*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4755*4bdc9457SAndroid Build Coastguard Worker }
4756*4bdc9457SAndroid Build Coastguard Worker }
4757*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_fulltile_with_zero)4758*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_fulltile_with_zero) {
4759*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4760*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4761*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4762*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4763*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4764*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4765*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4766*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4767*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4769*4bdc9457SAndroid Build Coastguard Worker }
4770*4bdc9457SAndroid Build Coastguard Worker }
4771*4bdc9457SAndroid Build Coastguard Worker }
4772*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_fulltile_with_qmin)4773*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_fulltile_with_qmin) {
4774*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4775*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4776*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4777*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4778*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4779*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4780*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4782*4bdc9457SAndroid Build Coastguard Worker }
4783*4bdc9457SAndroid Build Coastguard Worker }
4784*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_fulltile_with_qmax)4785*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_fulltile_with_qmax) {
4786*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4787*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4788*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4789*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4790*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4791*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4792*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4793*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4794*4bdc9457SAndroid Build Coastguard Worker }
4795*4bdc9457SAndroid Build Coastguard Worker }
4796*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_subtile)4797*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_subtile) {
4798*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4799*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4800*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4801*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4802*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4803*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4804*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4805*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4806*4bdc9457SAndroid Build Coastguard Worker }
4807*4bdc9457SAndroid Build Coastguard Worker }
4808*4bdc9457SAndroid Build Coastguard Worker }
4809*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_subtile_with_input_offset)4810*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_subtile_with_input_offset) {
4811*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4812*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4813*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4814*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4815*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4816*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4817*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4818*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4820*4bdc9457SAndroid Build Coastguard Worker }
4821*4bdc9457SAndroid Build Coastguard Worker }
4822*4bdc9457SAndroid Build Coastguard Worker }
4823*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_lt_4_unipass_subtile_with_zero)4824*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_lt_4_unipass_subtile_with_zero) {
4825*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4826*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4827*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
4828*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4829*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4830*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4831*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4832*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4833*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
4834*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4835*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4836*4bdc9457SAndroid Build Coastguard Worker }
4837*4bdc9457SAndroid Build Coastguard Worker }
4838*4bdc9457SAndroid Build Coastguard Worker }
4839*4bdc9457SAndroid Build Coastguard Worker }
4840*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_fulltile)4841*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_fulltile) {
4842*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4843*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4844*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4845*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4846*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4847*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4848*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4849*4bdc9457SAndroid Build Coastguard Worker }
4850*4bdc9457SAndroid Build Coastguard Worker }
4851*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_fulltile_with_input_offset)4852*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_fulltile_with_input_offset) {
4853*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4854*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4855*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4856*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4857*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4858*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4859*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4860*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4861*4bdc9457SAndroid Build Coastguard Worker }
4862*4bdc9457SAndroid Build Coastguard Worker }
4863*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_fulltile_with_zero)4864*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_fulltile_with_zero) {
4865*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4866*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4867*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
4868*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4869*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4870*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4871*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4872*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4873*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4874*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4875*4bdc9457SAndroid Build Coastguard Worker }
4876*4bdc9457SAndroid Build Coastguard Worker }
4877*4bdc9457SAndroid Build Coastguard Worker }
4878*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_fulltile_with_qmin)4879*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_fulltile_with_qmin) {
4880*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4881*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4882*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4883*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4884*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4885*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4886*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4888*4bdc9457SAndroid Build Coastguard Worker }
4889*4bdc9457SAndroid Build Coastguard Worker }
4890*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_fulltile_with_qmax)4891*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_fulltile_with_qmax) {
4892*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4893*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4894*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4895*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
4896*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4897*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4898*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4899*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4900*4bdc9457SAndroid Build Coastguard Worker }
4901*4bdc9457SAndroid Build Coastguard Worker }
4902*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_subtile)4903*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_subtile) {
4904*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4905*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4906*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4907*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4908*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4909*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4910*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4911*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4912*4bdc9457SAndroid Build Coastguard Worker }
4913*4bdc9457SAndroid Build Coastguard Worker }
4914*4bdc9457SAndroid Build Coastguard Worker }
4915*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_subtile_with_input_offset)4916*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_subtile_with_input_offset) {
4917*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4918*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4919*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4920*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4921*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4922*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4923*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4924*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4925*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4926*4bdc9457SAndroid Build Coastguard Worker }
4927*4bdc9457SAndroid Build Coastguard Worker }
4928*4bdc9457SAndroid Build Coastguard Worker }
4929*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,channels_gt_4_unipass_subtile_with_zero)4930*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, channels_gt_4_unipass_subtile_with_zero) {
4931*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4932*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
4933*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
4934*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4935*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4936*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4937*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
4938*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4939*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
4940*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4941*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4942*4bdc9457SAndroid Build Coastguard Worker }
4943*4bdc9457SAndroid Build Coastguard Worker }
4944*4bdc9457SAndroid Build Coastguard Worker }
4945*4bdc9457SAndroid Build Coastguard Worker }
4946*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels)4947*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels) {
4948*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4949*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4950*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4951*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4952*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4953*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4954*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4955*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4956*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4957*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4958*4bdc9457SAndroid Build Coastguard Worker }
4959*4bdc9457SAndroid Build Coastguard Worker }
4960*4bdc9457SAndroid Build Coastguard Worker }
4961*4bdc9457SAndroid Build Coastguard Worker }
4962*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_input_offset)4963*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_input_offset) {
4964*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4965*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4966*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4967*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4968*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4969*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4970*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4971*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4972*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4973*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
4974*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4975*4bdc9457SAndroid Build Coastguard Worker }
4976*4bdc9457SAndroid Build Coastguard Worker }
4977*4bdc9457SAndroid Build Coastguard Worker }
4978*4bdc9457SAndroid Build Coastguard Worker }
4979*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_zero)4980*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_zero) {
4981*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4982*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
4983*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
4984*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
4985*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
4986*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
4987*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
4988*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
4989*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
4990*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4991*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
4992*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
4993*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
4994*4bdc9457SAndroid Build Coastguard Worker }
4995*4bdc9457SAndroid Build Coastguard Worker }
4996*4bdc9457SAndroid Build Coastguard Worker }
4997*4bdc9457SAndroid Build Coastguard Worker }
4998*4bdc9457SAndroid Build Coastguard Worker }
4999*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_qmin)5000*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_qmin) {
5001*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
5002*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5003*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5004*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5005*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5006*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5007*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5008*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5009*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5010*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
5012*4bdc9457SAndroid Build Coastguard Worker }
5013*4bdc9457SAndroid Build Coastguard Worker }
5014*4bdc9457SAndroid Build Coastguard Worker }
5015*4bdc9457SAndroid Build Coastguard Worker }
5016*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_qmax)5017*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_qmax) {
5018*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
5019*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5020*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5021*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5022*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5023*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5024*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5025*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5026*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5027*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
5029*4bdc9457SAndroid Build Coastguard Worker }
5030*4bdc9457SAndroid Build Coastguard Worker }
5031*4bdc9457SAndroid Build Coastguard Worker }
5032*4bdc9457SAndroid Build Coastguard Worker }
5033*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_output_stride)5034*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_output_stride) {
5035*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
5036*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5037*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5038*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5039*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5040*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5041*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5042*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5043*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5044*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
5045*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
5046*4bdc9457SAndroid Build Coastguard Worker }
5047*4bdc9457SAndroid Build Coastguard Worker }
5048*4bdc9457SAndroid Build Coastguard Worker }
5049*4bdc9457SAndroid Build Coastguard Worker }
5050*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4,few_output_pixels_with_step)5051*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SSE_C4, few_output_pixels_with_step) {
5052*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
5053*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5054*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5055*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5056*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
5057*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5058*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5059*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5060*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5061*4bdc9457SAndroid Build Coastguard Worker .step(step)
5062*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5063*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
5064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__sse_c4, xnn_init_f32_minmax_sse_params);
5065*4bdc9457SAndroid Build Coastguard Worker }
5066*4bdc9457SAndroid Build Coastguard Worker }
5067*4bdc9457SAndroid Build Coastguard Worker }
5068*4bdc9457SAndroid Build Coastguard Worker }
5069*4bdc9457SAndroid Build Coastguard Worker }
5070*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
5071*4bdc9457SAndroid Build Coastguard Worker
5072*4bdc9457SAndroid Build Coastguard Worker
5073*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_fulltile)5074*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_fulltile) {
5075*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5076*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5077*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5078*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5079*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5080*4bdc9457SAndroid Build Coastguard Worker }
5081*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_fulltile_with_input_offset)5082*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_fulltile_with_input_offset) {
5083*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5084*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5085*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5086*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5087*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5088*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5089*4bdc9457SAndroid Build Coastguard Worker }
5090*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_fulltile_with_zero)5091*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_fulltile_with_zero) {
5092*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5093*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5094*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5095*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5096*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5097*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5098*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5099*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5100*4bdc9457SAndroid Build Coastguard Worker }
5101*4bdc9457SAndroid Build Coastguard Worker }
5102*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_fulltile_with_qmin)5103*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_fulltile_with_qmin) {
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(4)
5108*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5109*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5110*4bdc9457SAndroid Build Coastguard Worker }
5111*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_fulltile_with_qmax)5112*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_fulltile_with_qmax) {
5113*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5114*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5115*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5116*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5117*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5118*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5119*4bdc9457SAndroid Build Coastguard Worker }
5120*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_subtile)5121*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_subtile) {
5122*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5123*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5124*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5125*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5126*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5127*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5128*4bdc9457SAndroid Build Coastguard Worker }
5129*4bdc9457SAndroid Build Coastguard Worker }
5130*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_subtile_with_input_offset)5131*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_subtile_with_input_offset) {
5132*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5133*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5134*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5135*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5136*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5137*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5139*4bdc9457SAndroid Build Coastguard Worker }
5140*4bdc9457SAndroid Build Coastguard Worker }
5141*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_eq_4_unipass_subtile_with_zero)5142*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_eq_4_unipass_subtile_with_zero) {
5143*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5144*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5145*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5146*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5147*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5148*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5149*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5150*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5152*4bdc9457SAndroid Build Coastguard Worker }
5153*4bdc9457SAndroid Build Coastguard Worker }
5154*4bdc9457SAndroid Build Coastguard Worker }
5155*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_fulltile)5156*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_fulltile) {
5157*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5158*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5159*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5160*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5161*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5162*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5163*4bdc9457SAndroid Build Coastguard Worker }
5164*4bdc9457SAndroid Build Coastguard Worker }
5165*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_fulltile_with_input_offset)5166*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_fulltile_with_input_offset) {
5167*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
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(channels)
5172*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5174*4bdc9457SAndroid Build Coastguard Worker }
5175*4bdc9457SAndroid Build Coastguard Worker }
5176*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_fulltile_with_zero)5177*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_fulltile_with_zero) {
5178*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5179*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5180*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5181*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5182*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5183*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5184*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5185*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5186*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5187*4bdc9457SAndroid Build Coastguard Worker }
5188*4bdc9457SAndroid Build Coastguard Worker }
5189*4bdc9457SAndroid Build Coastguard Worker }
5190*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_fulltile_with_qmin)5191*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_fulltile_with_qmin) {
5192*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5193*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5194*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5195*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5196*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5197*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5198*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5199*4bdc9457SAndroid Build Coastguard Worker }
5200*4bdc9457SAndroid Build Coastguard Worker }
5201*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_fulltile_with_qmax)5202*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_fulltile_with_qmax) {
5203*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5204*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5205*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5206*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5207*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5208*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5209*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5210*4bdc9457SAndroid Build Coastguard Worker }
5211*4bdc9457SAndroid Build Coastguard Worker }
5212*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_subtile)5213*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_subtile) {
5214*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5215*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5216*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5217*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5218*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5219*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5220*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5221*4bdc9457SAndroid Build Coastguard Worker }
5222*4bdc9457SAndroid Build Coastguard Worker }
5223*4bdc9457SAndroid Build Coastguard Worker }
5224*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_subtile_with_input_offset)5225*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_subtile_with_input_offset) {
5226*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5227*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5228*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5229*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5230*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5231*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5232*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5233*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5234*4bdc9457SAndroid Build Coastguard Worker }
5235*4bdc9457SAndroid Build Coastguard Worker }
5236*4bdc9457SAndroid Build Coastguard Worker }
5237*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_div_4_unipass_subtile_with_zero)5238*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_div_4_unipass_subtile_with_zero) {
5239*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5240*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5241*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5242*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5243*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5244*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5245*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5246*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5247*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5248*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5249*4bdc9457SAndroid Build Coastguard Worker }
5250*4bdc9457SAndroid Build Coastguard Worker }
5251*4bdc9457SAndroid Build Coastguard Worker }
5252*4bdc9457SAndroid Build Coastguard Worker }
5253*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_fulltile)5254*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_fulltile) {
5255*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5256*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5257*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5258*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5259*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5260*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5261*4bdc9457SAndroid Build Coastguard Worker }
5262*4bdc9457SAndroid Build Coastguard Worker }
5263*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_fulltile_with_input_offset)5264*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_fulltile_with_input_offset) {
5265*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5266*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5267*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5268*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5269*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5270*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5272*4bdc9457SAndroid Build Coastguard Worker }
5273*4bdc9457SAndroid Build Coastguard Worker }
5274*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_fulltile_with_zero)5275*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_fulltile_with_zero) {
5276*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5277*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5278*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5279*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5280*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5281*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5282*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5283*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5284*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5285*4bdc9457SAndroid Build Coastguard Worker }
5286*4bdc9457SAndroid Build Coastguard Worker }
5287*4bdc9457SAndroid Build Coastguard Worker }
5288*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_fulltile_with_qmin)5289*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_fulltile_with_qmin) {
5290*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5291*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5292*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5293*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5294*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5295*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5296*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5297*4bdc9457SAndroid Build Coastguard Worker }
5298*4bdc9457SAndroid Build Coastguard Worker }
5299*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_fulltile_with_qmax)5300*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_fulltile_with_qmax) {
5301*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5302*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5303*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5304*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5305*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5306*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5307*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5308*4bdc9457SAndroid Build Coastguard Worker }
5309*4bdc9457SAndroid Build Coastguard Worker }
5310*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_subtile)5311*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_subtile) {
5312*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5313*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5314*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5315*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5316*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5317*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5318*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5319*4bdc9457SAndroid Build Coastguard Worker }
5320*4bdc9457SAndroid Build Coastguard Worker }
5321*4bdc9457SAndroid Build Coastguard Worker }
5322*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_subtile_with_input_offset)5323*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_subtile_with_input_offset) {
5324*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5325*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5326*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5327*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5328*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5329*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5330*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5331*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5332*4bdc9457SAndroid Build Coastguard Worker }
5333*4bdc9457SAndroid Build Coastguard Worker }
5334*4bdc9457SAndroid Build Coastguard Worker }
5335*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_lt_4_unipass_subtile_with_zero)5336*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_lt_4_unipass_subtile_with_zero) {
5337*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5338*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5339*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5340*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5341*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5342*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5343*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5344*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5345*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5346*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5347*4bdc9457SAndroid Build Coastguard Worker }
5348*4bdc9457SAndroid Build Coastguard Worker }
5349*4bdc9457SAndroid Build Coastguard Worker }
5350*4bdc9457SAndroid Build Coastguard Worker }
5351*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_fulltile)5352*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_fulltile) {
5353*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5354*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5355*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5356*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5357*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5358*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5359*4bdc9457SAndroid Build Coastguard Worker }
5360*4bdc9457SAndroid Build Coastguard Worker }
5361*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_fulltile_with_input_offset)5362*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_fulltile_with_input_offset) {
5363*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5364*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5365*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5366*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5367*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5368*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5369*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5370*4bdc9457SAndroid Build Coastguard Worker }
5371*4bdc9457SAndroid Build Coastguard Worker }
5372*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_fulltile_with_zero)5373*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_fulltile_with_zero) {
5374*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5375*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5376*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5377*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5378*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5379*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5380*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5381*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5382*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5383*4bdc9457SAndroid Build Coastguard Worker }
5384*4bdc9457SAndroid Build Coastguard Worker }
5385*4bdc9457SAndroid Build Coastguard Worker }
5386*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_fulltile_with_qmin)5387*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_fulltile_with_qmin) {
5388*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5389*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5390*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5391*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5392*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5393*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5394*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5395*4bdc9457SAndroid Build Coastguard Worker }
5396*4bdc9457SAndroid Build Coastguard Worker }
5397*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_fulltile_with_qmax)5398*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_fulltile_with_qmax) {
5399*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5400*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5401*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5402*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5403*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5404*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5405*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5406*4bdc9457SAndroid Build Coastguard Worker }
5407*4bdc9457SAndroid Build Coastguard Worker }
5408*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_subtile)5409*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_subtile) {
5410*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5411*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5412*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5413*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5414*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5415*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5416*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5417*4bdc9457SAndroid Build Coastguard Worker }
5418*4bdc9457SAndroid Build Coastguard Worker }
5419*4bdc9457SAndroid Build Coastguard Worker }
5420*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_subtile_with_input_offset)5421*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_subtile_with_input_offset) {
5422*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5423*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5424*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5425*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5426*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5427*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5428*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5429*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5430*4bdc9457SAndroid Build Coastguard Worker }
5431*4bdc9457SAndroid Build Coastguard Worker }
5432*4bdc9457SAndroid Build Coastguard Worker }
5433*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,channels_gt_4_unipass_subtile_with_zero)5434*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, channels_gt_4_unipass_subtile_with_zero) {
5435*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5436*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5437*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5438*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5439*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5440*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5441*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5442*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5443*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5444*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5445*4bdc9457SAndroid Build Coastguard Worker }
5446*4bdc9457SAndroid Build Coastguard Worker }
5447*4bdc9457SAndroid Build Coastguard Worker }
5448*4bdc9457SAndroid Build Coastguard Worker }
5449*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels)5450*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels) {
5451*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5452*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5453*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5454*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5455*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5456*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5457*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5458*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5459*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
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(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_input_offset)5465*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_input_offset) {
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 <= 20; channels += 3) {
5469*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5470*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5471*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5472*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5473*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5474*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
5475*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5476*4bdc9457SAndroid Build Coastguard Worker }
5477*4bdc9457SAndroid Build Coastguard Worker }
5478*4bdc9457SAndroid Build Coastguard Worker }
5479*4bdc9457SAndroid Build Coastguard Worker }
5480*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_zero)5481*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_zero) {
5482*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5483*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5484*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5485*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5486*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5487*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5488*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5489*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5490*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5491*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
5492*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5493*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_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 }
5499*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_qmin)5500*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_qmin) {
5501*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5502*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5503*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5504*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5505*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5506*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5507*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5508*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5509*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5511*4bdc9457SAndroid Build Coastguard Worker }
5512*4bdc9457SAndroid Build Coastguard Worker }
5513*4bdc9457SAndroid Build Coastguard Worker }
5514*4bdc9457SAndroid Build Coastguard Worker }
5515*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_qmax)5516*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_qmax) {
5517*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5518*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5519*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5520*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5521*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5522*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5523*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5524*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5525*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5526*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5527*4bdc9457SAndroid Build Coastguard Worker }
5528*4bdc9457SAndroid Build Coastguard Worker }
5529*4bdc9457SAndroid Build Coastguard Worker }
5530*4bdc9457SAndroid Build Coastguard Worker }
5531*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_output_stride)5532*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_output_stride) {
5533*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5534*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5535*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
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 .channels(channels)
5541*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
5542*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5543*4bdc9457SAndroid Build Coastguard Worker }
5544*4bdc9457SAndroid Build Coastguard Worker }
5545*4bdc9457SAndroid Build Coastguard Worker }
5546*4bdc9457SAndroid Build Coastguard Worker }
5547*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4,few_output_pixels_with_step)5548*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_ARM_C4, few_output_pixels_with_step) {
5549*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5550*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5551*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5552*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
5553*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5554*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5555*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5556*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5557*4bdc9457SAndroid Build Coastguard Worker .step(step)
5558*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5559*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
5560*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_arm_c4, xnn_init_f32_minmax_wasmsimd_params);
5561*4bdc9457SAndroid Build Coastguard Worker }
5562*4bdc9457SAndroid Build Coastguard Worker }
5563*4bdc9457SAndroid Build Coastguard Worker }
5564*4bdc9457SAndroid Build Coastguard Worker }
5565*4bdc9457SAndroid Build Coastguard Worker }
5566*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
5567*4bdc9457SAndroid Build Coastguard Worker
5568*4bdc9457SAndroid Build Coastguard Worker
5569*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_fulltile)5570*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_fulltile) {
5571*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5572*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5573*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5574*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5575*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5576*4bdc9457SAndroid Build Coastguard Worker }
5577*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_fulltile_with_input_offset)5578*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_fulltile_with_input_offset) {
5579*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5580*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5581*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5582*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5583*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5584*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5585*4bdc9457SAndroid Build Coastguard Worker }
5586*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_fulltile_with_zero)5587*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_fulltile_with_zero) {
5588*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5589*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5590*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5591*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5592*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5593*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5594*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5595*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5596*4bdc9457SAndroid Build Coastguard Worker }
5597*4bdc9457SAndroid Build Coastguard Worker }
5598*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_fulltile_with_qmin)5599*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_fulltile_with_qmin) {
5600*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5601*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5602*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5603*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5604*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5606*4bdc9457SAndroid Build Coastguard Worker }
5607*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_fulltile_with_qmax)5608*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_fulltile_with_qmax) {
5609*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5610*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5611*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5612*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5613*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5614*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5615*4bdc9457SAndroid Build Coastguard Worker }
5616*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_subtile)5617*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_subtile) {
5618*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5619*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5620*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5621*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5622*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5623*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5624*4bdc9457SAndroid Build Coastguard Worker }
5625*4bdc9457SAndroid Build Coastguard Worker }
5626*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_subtile_with_input_offset)5627*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_subtile_with_input_offset) {
5628*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5629*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5630*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5631*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5632*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5633*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5635*4bdc9457SAndroid Build Coastguard Worker }
5636*4bdc9457SAndroid Build Coastguard Worker }
5637*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_eq_4_unipass_subtile_with_zero)5638*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_eq_4_unipass_subtile_with_zero) {
5639*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5640*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5641*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5642*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5643*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5644*4bdc9457SAndroid Build Coastguard Worker .channels(4)
5645*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
5646*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5647*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5648*4bdc9457SAndroid Build Coastguard Worker }
5649*4bdc9457SAndroid Build Coastguard Worker }
5650*4bdc9457SAndroid Build Coastguard Worker }
5651*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_fulltile)5652*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_fulltile) {
5653*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5654*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5655*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5656*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5657*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5659*4bdc9457SAndroid Build Coastguard Worker }
5660*4bdc9457SAndroid Build Coastguard Worker }
5661*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_fulltile_with_input_offset)5662*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_fulltile_with_input_offset) {
5663*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5664*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5665*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5666*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5667*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5668*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5669*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5670*4bdc9457SAndroid Build Coastguard Worker }
5671*4bdc9457SAndroid Build Coastguard Worker }
5672*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_fulltile_with_zero)5673*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_fulltile_with_zero) {
5674*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5675*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5676*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5677*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5678*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5679*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5680*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5681*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5682*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5683*4bdc9457SAndroid Build Coastguard Worker }
5684*4bdc9457SAndroid Build Coastguard Worker }
5685*4bdc9457SAndroid Build Coastguard Worker }
5686*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_fulltile_with_qmin)5687*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_fulltile_with_qmin) {
5688*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5689*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5690*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5691*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5692*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5693*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5694*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5695*4bdc9457SAndroid Build Coastguard Worker }
5696*4bdc9457SAndroid Build Coastguard Worker }
5697*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_fulltile_with_qmax)5698*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_fulltile_with_qmax) {
5699*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5700*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5701*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5702*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5703*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5704*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5705*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5706*4bdc9457SAndroid Build Coastguard Worker }
5707*4bdc9457SAndroid Build Coastguard Worker }
5708*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_subtile)5709*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_subtile) {
5710*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5711*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5712*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5713*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5714*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5715*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5716*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5717*4bdc9457SAndroid Build Coastguard Worker }
5718*4bdc9457SAndroid Build Coastguard Worker }
5719*4bdc9457SAndroid Build Coastguard Worker }
5720*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_subtile_with_input_offset)5721*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_subtile_with_input_offset) {
5722*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5723*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5724*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5725*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5726*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5727*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5728*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5729*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5730*4bdc9457SAndroid Build Coastguard Worker }
5731*4bdc9457SAndroid Build Coastguard Worker }
5732*4bdc9457SAndroid Build Coastguard Worker }
5733*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_div_4_unipass_subtile_with_zero)5734*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_div_4_unipass_subtile_with_zero) {
5735*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5736*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 8; channels < 32; channels += 4) {
5737*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5738*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5739*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5740*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5741*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5742*4bdc9457SAndroid Build Coastguard Worker .input_offset(37)
5743*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5745*4bdc9457SAndroid Build Coastguard Worker }
5746*4bdc9457SAndroid Build Coastguard Worker }
5747*4bdc9457SAndroid Build Coastguard Worker }
5748*4bdc9457SAndroid Build Coastguard Worker }
5749*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_fulltile)5750*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_fulltile) {
5751*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5752*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5753*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5754*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5755*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5756*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5757*4bdc9457SAndroid Build Coastguard Worker }
5758*4bdc9457SAndroid Build Coastguard Worker }
5759*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_fulltile_with_input_offset)5760*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_fulltile_with_input_offset) {
5761*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5762*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5763*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5764*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5765*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5766*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5767*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5768*4bdc9457SAndroid Build Coastguard Worker }
5769*4bdc9457SAndroid Build Coastguard Worker }
5770*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_fulltile_with_zero)5771*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_fulltile_with_zero) {
5772*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5773*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5774*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5775*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5776*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5777*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5778*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5779*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5780*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5781*4bdc9457SAndroid Build Coastguard Worker }
5782*4bdc9457SAndroid Build Coastguard Worker }
5783*4bdc9457SAndroid Build Coastguard Worker }
5784*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_fulltile_with_qmin)5785*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_fulltile_with_qmin) {
5786*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5787*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5788*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5789*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5790*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5791*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5792*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5793*4bdc9457SAndroid Build Coastguard Worker }
5794*4bdc9457SAndroid Build Coastguard Worker }
5795*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_fulltile_with_qmax)5796*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_fulltile_with_qmax) {
5797*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5798*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5799*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5800*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5801*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5802*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5803*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5804*4bdc9457SAndroid Build Coastguard Worker }
5805*4bdc9457SAndroid Build Coastguard Worker }
5806*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_subtile)5807*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_subtile) {
5808*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5809*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5810*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5811*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5812*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5813*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5814*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5815*4bdc9457SAndroid Build Coastguard Worker }
5816*4bdc9457SAndroid Build Coastguard Worker }
5817*4bdc9457SAndroid Build Coastguard Worker }
5818*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_subtile_with_input_offset)5819*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_subtile_with_input_offset) {
5820*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5821*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5822*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5823*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5824*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5825*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5826*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5827*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5828*4bdc9457SAndroid Build Coastguard Worker }
5829*4bdc9457SAndroid Build Coastguard Worker }
5830*4bdc9457SAndroid Build Coastguard Worker }
5831*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_lt_4_unipass_subtile_with_zero)5832*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_lt_4_unipass_subtile_with_zero) {
5833*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5834*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels < 4; channels++) {
5835*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5836*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5837*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5838*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5839*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5840*4bdc9457SAndroid Build Coastguard Worker .input_offset(5)
5841*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5842*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5843*4bdc9457SAndroid Build Coastguard Worker }
5844*4bdc9457SAndroid Build Coastguard Worker }
5845*4bdc9457SAndroid Build Coastguard Worker }
5846*4bdc9457SAndroid Build Coastguard Worker }
5847*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_fulltile)5848*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_fulltile) {
5849*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5850*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5851*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5852*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5853*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5855*4bdc9457SAndroid Build Coastguard Worker }
5856*4bdc9457SAndroid Build Coastguard Worker }
5857*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_fulltile_with_input_offset)5858*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_fulltile_with_input_offset) {
5859*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5860*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5861*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5862*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5863*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5864*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5865*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5866*4bdc9457SAndroid Build Coastguard Worker }
5867*4bdc9457SAndroid Build Coastguard Worker }
5868*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_fulltile_with_zero)5869*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_fulltile_with_zero) {
5870*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5871*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
5872*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5873*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5874*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5875*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5876*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5877*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5878*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5879*4bdc9457SAndroid Build Coastguard Worker }
5880*4bdc9457SAndroid Build Coastguard Worker }
5881*4bdc9457SAndroid Build Coastguard Worker }
5882*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_fulltile_with_qmin)5883*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_fulltile_with_qmin) {
5884*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5885*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5886*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5887*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5888*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5889*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5890*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5891*4bdc9457SAndroid Build Coastguard Worker }
5892*4bdc9457SAndroid Build Coastguard Worker }
5893*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_fulltile_with_qmax)5894*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_fulltile_with_qmax) {
5895*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5896*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5897*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
5898*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5899*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5900*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5902*4bdc9457SAndroid Build Coastguard Worker }
5903*4bdc9457SAndroid Build Coastguard Worker }
5904*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_subtile)5905*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_subtile) {
5906*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5907*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5908*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5909*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5910*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5911*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5912*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5913*4bdc9457SAndroid Build Coastguard Worker }
5914*4bdc9457SAndroid Build Coastguard Worker }
5915*4bdc9457SAndroid Build Coastguard Worker }
5916*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_subtile_with_input_offset)5917*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_subtile_with_input_offset) {
5918*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5919*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5920*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5921*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5922*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5923*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5924*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5925*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5926*4bdc9457SAndroid Build Coastguard Worker }
5927*4bdc9457SAndroid Build Coastguard Worker }
5928*4bdc9457SAndroid Build Coastguard Worker }
5929*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,channels_gt_4_unipass_subtile_with_zero)5930*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, channels_gt_4_unipass_subtile_with_zero) {
5931*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
5932*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 5; channels < 8; channels++) {
5933*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5934*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5935*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5936*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
5937*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5938*4bdc9457SAndroid Build Coastguard Worker .input_offset(11)
5939*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5940*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5941*4bdc9457SAndroid Build Coastguard Worker }
5942*4bdc9457SAndroid Build Coastguard Worker }
5943*4bdc9457SAndroid Build Coastguard Worker }
5944*4bdc9457SAndroid Build Coastguard Worker }
5945*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels)5946*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels) {
5947*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5948*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5949*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5950*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5951*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5952*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5953*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5954*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5955*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5956*4bdc9457SAndroid Build Coastguard Worker }
5957*4bdc9457SAndroid Build Coastguard Worker }
5958*4bdc9457SAndroid Build Coastguard Worker }
5959*4bdc9457SAndroid Build Coastguard Worker }
5960*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_input_offset)5961*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_input_offset) {
5962*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5963*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5964*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5965*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5966*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5967*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5968*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5969*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5970*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
5971*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5972*4bdc9457SAndroid Build Coastguard Worker }
5973*4bdc9457SAndroid Build Coastguard Worker }
5974*4bdc9457SAndroid Build Coastguard Worker }
5975*4bdc9457SAndroid Build Coastguard Worker }
5976*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_zero)5977*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_zero) {
5978*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5979*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5980*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
5981*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
5982*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
5983*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
5984*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
5985*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
5986*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5987*4bdc9457SAndroid Build Coastguard Worker .input_offset(23)
5988*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
5989*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
5990*4bdc9457SAndroid Build Coastguard Worker }
5991*4bdc9457SAndroid Build Coastguard Worker }
5992*4bdc9457SAndroid Build Coastguard Worker }
5993*4bdc9457SAndroid Build Coastguard Worker }
5994*4bdc9457SAndroid Build Coastguard Worker }
5995*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_qmin)5996*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_qmin) {
5997*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
5998*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
5999*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
6000*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6001*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6002*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6003*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6004*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6005*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6006*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
6007*4bdc9457SAndroid Build Coastguard Worker }
6008*4bdc9457SAndroid Build Coastguard Worker }
6009*4bdc9457SAndroid Build Coastguard Worker }
6010*4bdc9457SAndroid Build Coastguard Worker }
6011*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_qmax)6012*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_qmax) {
6013*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6014*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6015*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
6016*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6017*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6018*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6019*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6020*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6021*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6022*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
6023*4bdc9457SAndroid Build Coastguard Worker }
6024*4bdc9457SAndroid Build Coastguard Worker }
6025*4bdc9457SAndroid Build Coastguard Worker }
6026*4bdc9457SAndroid Build Coastguard Worker }
6027*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_output_stride)6028*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_output_stride) {
6029*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6030*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6031*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
6032*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6033*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6034*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6035*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6036*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6037*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
6038*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
6039*4bdc9457SAndroid Build Coastguard Worker }
6040*4bdc9457SAndroid Build Coastguard Worker }
6041*4bdc9457SAndroid Build Coastguard Worker }
6042*4bdc9457SAndroid Build Coastguard Worker }
6043*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4,few_output_pixels_with_step)6044*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASMSIMD_X86_C4, few_output_pixels_with_step) {
6045*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6046*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6047*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 20; channels += 3) {
6048*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
6049*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6050*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6051*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6052*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6053*4bdc9457SAndroid Build Coastguard Worker .step(step)
6054*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6055*4bdc9457SAndroid Build Coastguard Worker .output_stride(23)
6056*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasmsimd_x86_c4, xnn_init_f32_minmax_wasmsimd_params);
6057*4bdc9457SAndroid Build Coastguard Worker }
6058*4bdc9457SAndroid Build Coastguard Worker }
6059*4bdc9457SAndroid Build Coastguard Worker }
6060*4bdc9457SAndroid Build Coastguard Worker }
6061*4bdc9457SAndroid Build Coastguard Worker }
6062*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
6063*4bdc9457SAndroid Build Coastguard Worker
6064*4bdc9457SAndroid Build Coastguard Worker
6065*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASM || XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_fulltile)6066*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_fulltile) {
6067*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6068*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6069*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6070*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6071*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6072*4bdc9457SAndroid Build Coastguard Worker }
6073*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_fulltile_with_input_offset)6074*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_fulltile_with_input_offset) {
6075*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6076*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6077*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6078*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6079*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6081*4bdc9457SAndroid Build Coastguard Worker }
6082*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_fulltile_with_zero)6083*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_fulltile_with_zero) {
6084*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
6085*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6086*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6087*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6088*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6089*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6090*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6091*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6092*4bdc9457SAndroid Build Coastguard Worker }
6093*4bdc9457SAndroid Build Coastguard Worker }
6094*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_fulltile_with_qmin)6095*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_fulltile_with_qmin) {
6096*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6097*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6098*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6099*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6100*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6101*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6102*4bdc9457SAndroid Build Coastguard Worker }
6103*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_fulltile_with_qmax)6104*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_fulltile_with_qmax) {
6105*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6106*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6107*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6108*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6109*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6110*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6111*4bdc9457SAndroid Build Coastguard Worker }
6112*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_subtile)6113*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_subtile) {
6114*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6115*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6116*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6117*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6118*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6119*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6120*4bdc9457SAndroid Build Coastguard Worker }
6121*4bdc9457SAndroid Build Coastguard Worker }
6122*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_subtile_with_input_offset)6123*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_subtile_with_input_offset) {
6124*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6125*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6126*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6127*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6128*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6129*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6130*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6131*4bdc9457SAndroid Build Coastguard Worker }
6132*4bdc9457SAndroid Build Coastguard Worker }
6133*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_eq_1_unipass_subtile_with_zero)6134*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_eq_1_unipass_subtile_with_zero) {
6135*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6136*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6137*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6138*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6139*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6140*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6141*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6142*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6143*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6144*4bdc9457SAndroid Build Coastguard Worker }
6145*4bdc9457SAndroid Build Coastguard Worker }
6146*4bdc9457SAndroid Build Coastguard Worker }
6147*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_fulltile)6148*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_fulltile) {
6149*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6150*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6151*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6152*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6153*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6155*4bdc9457SAndroid Build Coastguard Worker }
6156*4bdc9457SAndroid Build Coastguard Worker }
6157*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_fulltile_with_input_offset)6158*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_fulltile_with_input_offset) {
6159*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6160*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6161*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6162*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6163*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6164*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6166*4bdc9457SAndroid Build Coastguard Worker }
6167*4bdc9457SAndroid Build Coastguard Worker }
6168*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_fulltile_with_zero)6169*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_fulltile_with_zero) {
6170*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6171*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
6172*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6173*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6174*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6175*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6176*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6177*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6179*4bdc9457SAndroid Build Coastguard Worker }
6180*4bdc9457SAndroid Build Coastguard Worker }
6181*4bdc9457SAndroid Build Coastguard Worker }
6182*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_fulltile_with_qmin)6183*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_fulltile_with_qmin) {
6184*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6185*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6186*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6187*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6188*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6189*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6190*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6191*4bdc9457SAndroid Build Coastguard Worker }
6192*4bdc9457SAndroid Build Coastguard Worker }
6193*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_fulltile_with_qmax)6194*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_fulltile_with_qmax) {
6195*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6196*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6197*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6198*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6199*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6200*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6201*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6202*4bdc9457SAndroid Build Coastguard Worker }
6203*4bdc9457SAndroid Build Coastguard Worker }
6204*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_subtile)6205*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_subtile) {
6206*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6207*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6208*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6209*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6210*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6211*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6212*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6213*4bdc9457SAndroid Build Coastguard Worker }
6214*4bdc9457SAndroid Build Coastguard Worker }
6215*4bdc9457SAndroid Build Coastguard Worker }
6216*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_subtile_with_input_offset)6217*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_subtile_with_input_offset) {
6218*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6219*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6220*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6221*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6222*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6223*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6224*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6225*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6226*4bdc9457SAndroid Build Coastguard Worker }
6227*4bdc9457SAndroid Build Coastguard Worker }
6228*4bdc9457SAndroid Build Coastguard Worker }
6229*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,channels_gt_1_unipass_subtile_with_zero)6230*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, channels_gt_1_unipass_subtile_with_zero) {
6231*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6232*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6233*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6234*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6235*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6236*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6237*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6238*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6239*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6241*4bdc9457SAndroid Build Coastguard Worker }
6242*4bdc9457SAndroid Build Coastguard Worker }
6243*4bdc9457SAndroid Build Coastguard Worker }
6244*4bdc9457SAndroid Build Coastguard Worker }
6245*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels)6246*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels) {
6247*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6248*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6249*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6250*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6251*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6252*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6253*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6254*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6255*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6256*4bdc9457SAndroid Build Coastguard Worker }
6257*4bdc9457SAndroid Build Coastguard Worker }
6258*4bdc9457SAndroid Build Coastguard Worker }
6259*4bdc9457SAndroid Build Coastguard Worker }
6260*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_input_offset)6261*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_input_offset) {
6262*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6263*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6264*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6265*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6266*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6267*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6268*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6269*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6270*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
6271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6272*4bdc9457SAndroid Build Coastguard Worker }
6273*4bdc9457SAndroid Build Coastguard Worker }
6274*4bdc9457SAndroid Build Coastguard Worker }
6275*4bdc9457SAndroid Build Coastguard Worker }
6276*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_zero)6277*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_zero) {
6278*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6279*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6280*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6281*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6282*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6283*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6284*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6285*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6286*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6287*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
6288*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6289*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6290*4bdc9457SAndroid Build Coastguard Worker }
6291*4bdc9457SAndroid Build Coastguard Worker }
6292*4bdc9457SAndroid Build Coastguard Worker }
6293*4bdc9457SAndroid Build Coastguard Worker }
6294*4bdc9457SAndroid Build Coastguard Worker }
6295*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_qmin)6296*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_qmin) {
6297*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6298*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6299*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6300*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6301*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6302*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6303*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6304*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6305*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6306*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6307*4bdc9457SAndroid Build Coastguard Worker }
6308*4bdc9457SAndroid Build Coastguard Worker }
6309*4bdc9457SAndroid Build Coastguard Worker }
6310*4bdc9457SAndroid Build Coastguard Worker }
6311*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_qmax)6312*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_qmax) {
6313*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6314*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6315*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6316*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6317*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6318*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6319*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6320*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6321*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6322*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6323*4bdc9457SAndroid Build Coastguard Worker }
6324*4bdc9457SAndroid Build Coastguard Worker }
6325*4bdc9457SAndroid Build Coastguard Worker }
6326*4bdc9457SAndroid Build Coastguard Worker }
6327*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_output_stride)6328*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_output_stride) {
6329*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6330*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6331*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6332*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6333*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6334*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6335*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6336*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6337*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
6338*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6339*4bdc9457SAndroid Build Coastguard Worker }
6340*4bdc9457SAndroid Build Coastguard Worker }
6341*4bdc9457SAndroid Build Coastguard Worker }
6342*4bdc9457SAndroid Build Coastguard Worker }
6343*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1,few_output_pixels_with_step)6344*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__WASM_C1, few_output_pixels_with_step) {
6345*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6346*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6347*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6348*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
6349*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6350*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6351*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6352*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6353*4bdc9457SAndroid Build Coastguard Worker .step(step)
6354*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6355*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
6356*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__wasm_c1, xnn_init_f32_minmax_scalar_params);
6357*4bdc9457SAndroid Build Coastguard Worker }
6358*4bdc9457SAndroid Build Coastguard Worker }
6359*4bdc9457SAndroid Build Coastguard Worker }
6360*4bdc9457SAndroid Build Coastguard Worker }
6361*4bdc9457SAndroid Build Coastguard Worker }
6362*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASM || XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
6363*4bdc9457SAndroid Build Coastguard Worker
6364*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile)6365*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile) {
6366*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6367*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6368*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6369*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6370*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6371*4bdc9457SAndroid Build Coastguard Worker }
6372*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_input_offset)6373*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_input_offset) {
6374*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6375*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6376*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6377*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6378*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6379*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6380*4bdc9457SAndroid Build Coastguard Worker }
6381*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_zero)6382*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_zero) {
6383*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
6384*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6385*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6386*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6387*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6388*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6389*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6390*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6391*4bdc9457SAndroid Build Coastguard Worker }
6392*4bdc9457SAndroid Build Coastguard Worker }
6393*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_qmin)6394*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_qmin) {
6395*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6396*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6397*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6398*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6399*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6400*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6401*4bdc9457SAndroid Build Coastguard Worker }
6402*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_fulltile_with_qmax)6403*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_fulltile_with_qmax) {
6404*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6405*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6406*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6407*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6408*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6409*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6410*4bdc9457SAndroid Build Coastguard Worker }
6411*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile)6412*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile) {
6413*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6414*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6415*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6416*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6417*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6418*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6419*4bdc9457SAndroid Build Coastguard Worker }
6420*4bdc9457SAndroid Build Coastguard Worker }
6421*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile_with_input_offset)6422*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile_with_input_offset) {
6423*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6424*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6425*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6426*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6427*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6428*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6429*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6430*4bdc9457SAndroid Build Coastguard Worker }
6431*4bdc9457SAndroid Build Coastguard Worker }
6432*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_eq_1_unipass_subtile_with_zero)6433*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_eq_1_unipass_subtile_with_zero) {
6434*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6435*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6436*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6437*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6438*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6439*4bdc9457SAndroid Build Coastguard Worker .channels(1)
6440*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6441*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6442*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6443*4bdc9457SAndroid Build Coastguard Worker }
6444*4bdc9457SAndroid Build Coastguard Worker }
6445*4bdc9457SAndroid Build Coastguard Worker }
6446*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile)6447*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile) {
6448*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6449*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6450*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6451*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6452*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6453*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6454*4bdc9457SAndroid Build Coastguard Worker }
6455*4bdc9457SAndroid Build Coastguard Worker }
6456*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_input_offset)6457*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_input_offset) {
6458*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6459*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6460*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6461*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6462*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6463*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6464*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6465*4bdc9457SAndroid Build Coastguard Worker }
6466*4bdc9457SAndroid Build Coastguard Worker }
6467*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_zero)6468*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_zero) {
6469*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6470*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < 9; zero_index++) {
6471*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6472*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6473*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6474*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6475*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6476*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6477*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6478*4bdc9457SAndroid Build Coastguard Worker }
6479*4bdc9457SAndroid Build Coastguard Worker }
6480*4bdc9457SAndroid Build Coastguard Worker }
6481*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_qmin)6482*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_qmin) {
6483*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6484*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6485*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6486*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6487*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6488*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6489*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6490*4bdc9457SAndroid Build Coastguard Worker }
6491*4bdc9457SAndroid Build Coastguard Worker }
6492*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_fulltile_with_qmax)6493*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_fulltile_with_qmax) {
6494*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6495*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6496*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(9)
6497*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6498*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6499*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6500*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6501*4bdc9457SAndroid Build Coastguard Worker }
6502*4bdc9457SAndroid Build Coastguard Worker }
6503*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile)6504*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile) {
6505*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6506*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6507*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6508*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6509*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6510*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6511*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6512*4bdc9457SAndroid Build Coastguard Worker }
6513*4bdc9457SAndroid Build Coastguard Worker }
6514*4bdc9457SAndroid Build Coastguard Worker }
6515*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile_with_input_offset)6516*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile_with_input_offset) {
6517*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6518*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6519*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6520*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6521*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6522*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6523*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6525*4bdc9457SAndroid Build Coastguard Worker }
6526*4bdc9457SAndroid Build Coastguard Worker }
6527*4bdc9457SAndroid Build Coastguard Worker }
6528*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,channels_gt_1_unipass_subtile_with_zero)6529*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, channels_gt_1_unipass_subtile_with_zero) {
6530*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements = 2; pooling_elements < 9; pooling_elements++) {
6531*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 2; channels < 10; channels++) {
6532*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6533*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6534*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6535*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9)
6536*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6537*4bdc9457SAndroid Build Coastguard Worker .input_offset(3)
6538*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6539*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6540*4bdc9457SAndroid Build Coastguard Worker }
6541*4bdc9457SAndroid Build Coastguard Worker }
6542*4bdc9457SAndroid Build Coastguard Worker }
6543*4bdc9457SAndroid Build Coastguard Worker }
6544*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels)6545*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels) {
6546*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6547*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6548*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6549*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6550*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6551*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6552*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6553*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6554*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6555*4bdc9457SAndroid Build Coastguard Worker }
6556*4bdc9457SAndroid Build Coastguard Worker }
6557*4bdc9457SAndroid Build Coastguard Worker }
6558*4bdc9457SAndroid Build Coastguard Worker }
6559*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_input_offset)6560*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_input_offset) {
6561*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6562*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6563*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6564*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6565*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6566*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6567*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6568*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6569*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
6570*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6571*4bdc9457SAndroid Build Coastguard Worker }
6572*4bdc9457SAndroid Build Coastguard Worker }
6573*4bdc9457SAndroid Build Coastguard Worker }
6574*4bdc9457SAndroid Build Coastguard Worker }
6575*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_zero)6576*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_zero) {
6577*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6578*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6579*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6580*4bdc9457SAndroid Build Coastguard Worker for (size_t zero_index = 0; zero_index < pooling_elements; zero_index++) {
6581*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6582*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6583*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6584*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6585*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6586*4bdc9457SAndroid Build Coastguard Worker .input_offset(7)
6587*4bdc9457SAndroid Build Coastguard Worker .zero_index(zero_index)
6588*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6589*4bdc9457SAndroid Build Coastguard Worker }
6590*4bdc9457SAndroid Build Coastguard Worker }
6591*4bdc9457SAndroid Build Coastguard Worker }
6592*4bdc9457SAndroid Build Coastguard Worker }
6593*4bdc9457SAndroid Build Coastguard Worker }
6594*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_qmin)6595*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_qmin) {
6596*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6597*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6598*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6599*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6600*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6601*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6602*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6603*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6604*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6606*4bdc9457SAndroid Build Coastguard Worker }
6607*4bdc9457SAndroid Build Coastguard Worker }
6608*4bdc9457SAndroid Build Coastguard Worker }
6609*4bdc9457SAndroid Build Coastguard Worker }
6610*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_qmax)6611*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_qmax) {
6612*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6613*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6614*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6615*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6616*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6617*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6618*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6619*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6620*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6621*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6622*4bdc9457SAndroid Build Coastguard Worker }
6623*4bdc9457SAndroid Build Coastguard Worker }
6624*4bdc9457SAndroid Build Coastguard Worker }
6625*4bdc9457SAndroid Build Coastguard Worker }
6626*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_output_stride)6627*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_output_stride) {
6628*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6629*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6630*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6631*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6632*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6633*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6634*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6635*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6636*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
6637*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6638*4bdc9457SAndroid Build Coastguard Worker }
6639*4bdc9457SAndroid Build Coastguard Worker }
6640*4bdc9457SAndroid Build Coastguard Worker }
6641*4bdc9457SAndroid Build Coastguard Worker }
6642*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1,few_output_pixels_with_step)6643*4bdc9457SAndroid Build Coastguard Worker TEST(F32_PAVGPOOL_MINMAX_9X__SCALAR_C1, few_output_pixels_with_step) {
6644*4bdc9457SAndroid Build Coastguard Worker for (size_t output_pixels = 2; output_pixels <= 5; output_pixels++) {
6645*4bdc9457SAndroid Build Coastguard Worker for (size_t pooling_elements : std::vector<size_t>{{2, 8, 9}}) {
6646*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 5; channels += 1) {
6647*4bdc9457SAndroid Build Coastguard Worker for (size_t step = 2; step <= pooling_elements; step++) {
6648*4bdc9457SAndroid Build Coastguard Worker AvgPoolMicrokernelTester()
6649*4bdc9457SAndroid Build Coastguard Worker .output_pixels(output_pixels)
6650*4bdc9457SAndroid Build Coastguard Worker .pooling_elements(pooling_elements)
6651*4bdc9457SAndroid Build Coastguard Worker .pooling_tile(9, 0)
6652*4bdc9457SAndroid Build Coastguard Worker .step(step)
6653*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6654*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
6655*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_pavgpool_minmax_ukernel_9x__scalar_c1, xnn_init_f32_minmax_scalar_params);
6656*4bdc9457SAndroid Build Coastguard Worker }
6657*4bdc9457SAndroid Build Coastguard Worker }
6658*4bdc9457SAndroid Build Coastguard Worker }
6659*4bdc9457SAndroid Build Coastguard Worker }
6660*4bdc9457SAndroid Build Coastguard Worker }