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