xref: /aosp_15_r20/external/XNNPACK/test/max-pooling-nhwc.cc (revision 4bdc94577ba0e567308109d787f7fec7b531ce36)
1*4bdc9457SAndroid Build Coastguard Worker // Copyright (c) Facebook, Inc. and its affiliates.
2*4bdc9457SAndroid Build Coastguard Worker // All rights reserved.
3*4bdc9457SAndroid Build Coastguard Worker //
4*4bdc9457SAndroid Build Coastguard Worker // Copyright 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 #include <gtest/gtest.h>
10*4bdc9457SAndroid Build Coastguard Worker 
11*4bdc9457SAndroid Build Coastguard Worker #include "max-pooling-operator-tester.h"
12*4bdc9457SAndroid Build Coastguard Worker 
13*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/params.h>
14*4bdc9457SAndroid Build Coastguard Worker 
15*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_1xM_pool)16*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_1xM_pool) {
17*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
18*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
19*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
20*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
21*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
22*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
23*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
24*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
25*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
26*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
27*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
28*4bdc9457SAndroid Build Coastguard Worker     }
29*4bdc9457SAndroid Build Coastguard Worker   }
30*4bdc9457SAndroid Build Coastguard Worker }
31*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_1xM_pool_with_padding)32*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_1xM_pool_with_padding) {
33*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
34*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
35*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
36*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
37*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
38*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
39*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
40*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
41*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
42*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
43*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
44*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
45*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
46*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
47*4bdc9457SAndroid Build Coastguard Worker             .TestS8();
48*4bdc9457SAndroid Build Coastguard Worker         }
49*4bdc9457SAndroid Build Coastguard Worker       }
50*4bdc9457SAndroid Build Coastguard Worker     }
51*4bdc9457SAndroid Build Coastguard Worker   }
52*4bdc9457SAndroid Build Coastguard Worker }
53*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_1xM_pool_with_tf_same_padding)54*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_1xM_pool_with_tf_same_padding) {
55*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
56*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
57*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
58*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
59*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
60*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
61*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
62*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
63*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
64*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
65*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
66*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
67*4bdc9457SAndroid Build Coastguard Worker           .TestS8();
68*4bdc9457SAndroid Build Coastguard Worker       }
69*4bdc9457SAndroid Build Coastguard Worker     }
70*4bdc9457SAndroid Build Coastguard Worker   }
71*4bdc9457SAndroid Build Coastguard Worker }
72*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_1xM_pool_with_stride)73*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_1xM_pool_with_stride) {
74*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
75*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
76*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
77*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
78*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
79*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
80*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
81*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
82*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
83*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
84*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
85*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
86*4bdc9457SAndroid Build Coastguard Worker     }
87*4bdc9457SAndroid Build Coastguard Worker   }
88*4bdc9457SAndroid Build Coastguard Worker }
89*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_1xM_pool_with_dilation)90*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_1xM_pool_with_dilation) {
91*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
92*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
93*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
94*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
95*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
96*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
97*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
98*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
99*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
100*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
101*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
102*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
103*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
104*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
105*4bdc9457SAndroid Build Coastguard Worker     }
106*4bdc9457SAndroid Build Coastguard Worker   }
107*4bdc9457SAndroid Build Coastguard Worker }
108*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_Mx1_pool)109*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_Mx1_pool) {
110*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
111*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
112*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
113*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
114*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
115*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
116*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
117*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
118*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
119*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
120*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
121*4bdc9457SAndroid Build Coastguard Worker     }
122*4bdc9457SAndroid Build Coastguard Worker   }
123*4bdc9457SAndroid Build Coastguard Worker }
124*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_Mx1_pool_with_padding)125*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_Mx1_pool_with_padding) {
126*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
127*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
128*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
129*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
130*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
131*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
132*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
133*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
134*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
135*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
136*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
137*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
138*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
139*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
140*4bdc9457SAndroid Build Coastguard Worker             .TestS8();
141*4bdc9457SAndroid Build Coastguard Worker         }
142*4bdc9457SAndroid Build Coastguard Worker       }
143*4bdc9457SAndroid Build Coastguard Worker     }
144*4bdc9457SAndroid Build Coastguard Worker   }
145*4bdc9457SAndroid Build Coastguard Worker }
146*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_Mx1_pool_with_tf_same_padding)147*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_Mx1_pool_with_tf_same_padding) {
148*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
149*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
150*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
151*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
152*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
153*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
154*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
155*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
156*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
157*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
158*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
159*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
160*4bdc9457SAndroid Build Coastguard Worker           .TestS8();
161*4bdc9457SAndroid Build Coastguard Worker       }
162*4bdc9457SAndroid Build Coastguard Worker     }
163*4bdc9457SAndroid Build Coastguard Worker   }
164*4bdc9457SAndroid Build Coastguard Worker }
165*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_Mx1_pool_with_stride)166*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_Mx1_pool_with_stride) {
167*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
168*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
169*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
170*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
171*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
172*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
173*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
174*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
175*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
176*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
177*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
178*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
179*4bdc9457SAndroid Build Coastguard Worker     }
180*4bdc9457SAndroid Build Coastguard Worker   }
181*4bdc9457SAndroid Build Coastguard Worker }
182*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_Mx1_pool_with_dilation)183*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_Mx1_pool_with_dilation) {
184*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
185*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
186*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
187*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
188*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
189*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
190*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
191*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
192*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
193*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
194*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
195*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
196*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
197*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
198*4bdc9457SAndroid Build Coastguard Worker     }
199*4bdc9457SAndroid Build Coastguard Worker   }
200*4bdc9457SAndroid Build Coastguard Worker }
201*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_pool_with_input_stride)202*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_pool_with_input_stride) {
203*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
204*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
205*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
206*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
207*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
208*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
209*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
210*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
211*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
212*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
213*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
214*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
215*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
216*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
217*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
218*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
219*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
220*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
221*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
222*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
223*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
224*4bdc9457SAndroid Build Coastguard Worker     }
225*4bdc9457SAndroid Build Coastguard Worker   }
226*4bdc9457SAndroid Build Coastguard Worker }
227*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_pool_with_output_stride)228*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_pool_with_output_stride) {
229*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
230*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
231*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
232*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
233*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
234*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
235*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
236*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
237*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
238*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
239*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
240*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
241*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
242*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
243*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
244*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
245*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
246*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
247*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
248*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
249*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
250*4bdc9457SAndroid Build Coastguard Worker     }
251*4bdc9457SAndroid Build Coastguard Worker   }
252*4bdc9457SAndroid Build Coastguard Worker }
253*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_pool_with_qmin)254*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_pool_with_qmin) {
255*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
256*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
257*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
258*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
259*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
260*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
261*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
262*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
263*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
264*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
265*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
266*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
267*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
268*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
269*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
270*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
271*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
272*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
273*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
274*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
275*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
276*4bdc9457SAndroid Build Coastguard Worker     }
277*4bdc9457SAndroid Build Coastguard Worker   }
278*4bdc9457SAndroid Build Coastguard Worker }
279*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_small_pool_with_qmax)280*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_small_pool_with_qmax) {
281*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
282*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
283*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
284*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
285*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
286*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
287*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
288*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
289*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
290*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
291*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
292*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
293*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
294*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
295*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
296*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
297*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
298*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
299*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
300*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
301*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
302*4bdc9457SAndroid Build Coastguard Worker     }
303*4bdc9457SAndroid Build Coastguard Worker   }
304*4bdc9457SAndroid Build Coastguard Worker }
305*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_1xM_pool)306*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_1xM_pool) {
307*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
308*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
309*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
310*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
311*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
312*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
313*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
314*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
315*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
316*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
317*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
318*4bdc9457SAndroid Build Coastguard Worker     }
319*4bdc9457SAndroid Build Coastguard Worker   }
320*4bdc9457SAndroid Build Coastguard Worker }
321*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_1xM_pool_with_padding)322*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_1xM_pool_with_padding) {
323*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
324*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
325*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
326*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
327*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
328*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
329*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
330*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
331*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
332*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
333*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
334*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
335*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
336*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
337*4bdc9457SAndroid Build Coastguard Worker             .TestS8();
338*4bdc9457SAndroid Build Coastguard Worker         }
339*4bdc9457SAndroid Build Coastguard Worker       }
340*4bdc9457SAndroid Build Coastguard Worker     }
341*4bdc9457SAndroid Build Coastguard Worker   }
342*4bdc9457SAndroid Build Coastguard Worker }
343*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_1xM_pool_with_tf_same_padding)344*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_1xM_pool_with_tf_same_padding) {
345*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
346*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
347*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
348*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
349*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
350*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
351*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
352*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
353*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
354*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
355*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
356*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
357*4bdc9457SAndroid Build Coastguard Worker           .TestS8();
358*4bdc9457SAndroid Build Coastguard Worker       }
359*4bdc9457SAndroid Build Coastguard Worker     }
360*4bdc9457SAndroid Build Coastguard Worker   }
361*4bdc9457SAndroid Build Coastguard Worker }
362*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_1xM_pool_with_stride)363*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_1xM_pool_with_stride) {
364*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
365*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
366*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
367*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
368*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
369*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
370*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
371*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
372*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
373*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
374*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
375*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
376*4bdc9457SAndroid Build Coastguard Worker     }
377*4bdc9457SAndroid Build Coastguard Worker   }
378*4bdc9457SAndroid Build Coastguard Worker }
379*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_1xM_pool_with_dilation)380*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_1xM_pool_with_dilation) {
381*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
382*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
383*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
384*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
385*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
386*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
387*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
388*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
389*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
390*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
391*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
392*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
393*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
394*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
395*4bdc9457SAndroid Build Coastguard Worker     }
396*4bdc9457SAndroid Build Coastguard Worker   }
397*4bdc9457SAndroid Build Coastguard Worker }
398*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_Mx1_pool)399*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_Mx1_pool) {
400*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
401*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
402*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
403*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
404*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
405*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
406*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
407*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
408*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
409*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
410*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
411*4bdc9457SAndroid Build Coastguard Worker     }
412*4bdc9457SAndroid Build Coastguard Worker   }
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_Mx1_pool_with_padding)415*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_Mx1_pool_with_padding) {
416*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
417*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
418*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
419*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
420*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
421*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
422*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
423*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
424*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
425*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
426*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
427*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
428*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
429*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
430*4bdc9457SAndroid Build Coastguard Worker             .TestS8();
431*4bdc9457SAndroid Build Coastguard Worker         }
432*4bdc9457SAndroid Build Coastguard Worker       }
433*4bdc9457SAndroid Build Coastguard Worker     }
434*4bdc9457SAndroid Build Coastguard Worker   }
435*4bdc9457SAndroid Build Coastguard Worker }
436*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_Mx1_pool_with_tf_same_padding)437*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_Mx1_pool_with_tf_same_padding) {
438*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
439*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
440*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
441*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
442*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
443*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
444*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
445*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
446*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
447*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
448*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
449*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
450*4bdc9457SAndroid Build Coastguard Worker           .TestS8();
451*4bdc9457SAndroid Build Coastguard Worker       }
452*4bdc9457SAndroid Build Coastguard Worker     }
453*4bdc9457SAndroid Build Coastguard Worker   }
454*4bdc9457SAndroid Build Coastguard Worker }
455*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_Mx1_pool_with_stride)456*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_Mx1_pool_with_stride) {
457*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
458*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
459*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
460*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
461*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
462*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
463*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
464*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
465*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
466*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
467*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
468*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
469*4bdc9457SAndroid Build Coastguard Worker     }
470*4bdc9457SAndroid Build Coastguard Worker   }
471*4bdc9457SAndroid Build Coastguard Worker }
472*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_Mx1_pool_with_dilation)473*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_Mx1_pool_with_dilation) {
474*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
475*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
476*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
477*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
478*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
479*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
480*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
481*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
482*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
483*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
484*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
485*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
486*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
487*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
488*4bdc9457SAndroid Build Coastguard Worker     }
489*4bdc9457SAndroid Build Coastguard Worker   }
490*4bdc9457SAndroid Build Coastguard Worker }
491*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_pool_with_input_stride)492*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_pool_with_input_stride) {
493*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
494*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
495*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
496*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
497*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
498*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
499*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
500*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
501*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
502*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
503*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
504*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
505*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
506*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
507*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
508*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
509*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
510*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
511*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
512*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
513*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
514*4bdc9457SAndroid Build Coastguard Worker     }
515*4bdc9457SAndroid Build Coastguard Worker   }
516*4bdc9457SAndroid Build Coastguard Worker }
517*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_pool_with_output_stride)518*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_pool_with_output_stride) {
519*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
520*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
521*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
522*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
523*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
524*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
525*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
526*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
527*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
528*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
529*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
530*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
531*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
532*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
533*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
534*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
535*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
536*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
537*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
538*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
539*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
540*4bdc9457SAndroid Build Coastguard Worker     }
541*4bdc9457SAndroid Build Coastguard Worker   }
542*4bdc9457SAndroid Build Coastguard Worker }
543*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_pool_with_qmin)544*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_pool_with_qmin) {
545*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
546*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
547*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
548*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
549*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
550*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
551*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
552*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
553*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
554*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
555*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
556*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
557*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
558*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
559*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
560*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
561*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
562*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
563*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
564*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
565*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
566*4bdc9457SAndroid Build Coastguard Worker     }
567*4bdc9457SAndroid Build Coastguard Worker   }
568*4bdc9457SAndroid Build Coastguard Worker }
569*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,unit_batch_large_pool_with_qmax)570*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, unit_batch_large_pool_with_qmax) {
571*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
572*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
573*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
574*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
575*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
576*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
577*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
578*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
579*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
580*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
581*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
582*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
583*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
584*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
585*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
586*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
587*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
588*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
589*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
590*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
591*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
592*4bdc9457SAndroid Build Coastguard Worker     }
593*4bdc9457SAndroid Build Coastguard Worker   }
594*4bdc9457SAndroid Build Coastguard Worker }
595*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_small_pool)596*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_small_pool) {
597*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
598*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
599*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
600*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
601*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
602*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
603*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
604*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
605*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
606*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
607*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
608*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
609*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
610*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
611*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
612*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
613*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
614*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
615*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
616*4bdc9457SAndroid Build Coastguard Worker     }
617*4bdc9457SAndroid Build Coastguard Worker   }
618*4bdc9457SAndroid Build Coastguard Worker }
619*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_small_pool_with_input_stride)620*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_small_pool_with_input_stride) {
621*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
622*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
623*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
624*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
625*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
626*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
627*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
628*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
629*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
630*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
631*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
632*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
633*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
634*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
635*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
636*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
637*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
638*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
639*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
640*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
641*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
642*4bdc9457SAndroid Build Coastguard Worker     }
643*4bdc9457SAndroid Build Coastguard Worker   }
644*4bdc9457SAndroid Build Coastguard Worker }
645*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_small_pool_with_output_stride)646*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_small_pool_with_output_stride) {
647*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
648*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
649*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.s8.maxpool.mr; pool_size++) {
650*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
651*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
652*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
653*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
654*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
655*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
656*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
657*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
658*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
659*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
660*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
661*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
662*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
663*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
664*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
665*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
666*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
667*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
668*4bdc9457SAndroid Build Coastguard Worker     }
669*4bdc9457SAndroid Build Coastguard Worker   }
670*4bdc9457SAndroid Build Coastguard Worker }
671*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_large_pool)672*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_large_pool) {
673*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
674*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
675*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
676*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
677*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
678*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
679*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
680*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
681*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
682*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
683*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
684*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
685*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
686*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
687*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
688*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
689*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
690*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
691*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
692*4bdc9457SAndroid Build Coastguard Worker     }
693*4bdc9457SAndroid Build Coastguard Worker   }
694*4bdc9457SAndroid Build Coastguard Worker }
695*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_large_pool_with_input_stride)696*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_large_pool_with_input_stride) {
697*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
698*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
699*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
700*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
701*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
702*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
703*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
704*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
705*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
706*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
707*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
708*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
709*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
710*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
711*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
712*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
713*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
714*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
715*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
716*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
717*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
718*4bdc9457SAndroid Build Coastguard Worker     }
719*4bdc9457SAndroid Build Coastguard Worker   }
720*4bdc9457SAndroid Build Coastguard Worker }
721*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,small_batch_large_pool_with_output_stride)722*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, small_batch_large_pool_with_output_stride) {
723*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
724*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
725*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.s8.maxpool.mr + 1; pool_size <= xnn_params.s8.maxpool.mr + xnn_params.s8.maxpool.qr; pool_size++) {
726*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
727*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
728*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
729*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
730*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
731*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
732*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
733*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
734*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
735*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
736*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
737*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
738*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
739*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
740*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
741*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
742*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
743*4bdc9457SAndroid Build Coastguard Worker         .TestS8();
744*4bdc9457SAndroid Build Coastguard Worker     }
745*4bdc9457SAndroid Build Coastguard Worker   }
746*4bdc9457SAndroid Build Coastguard Worker }
747*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,setup_increasing_batch)748*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, setup_increasing_batch) {
749*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
750*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
751*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
752*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(5)
753*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
754*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
755*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
756*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
757*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
758*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
759*4bdc9457SAndroid Build Coastguard Worker }
760*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,setup_decreasing_batch)761*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, setup_decreasing_batch) {
762*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
763*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
764*4bdc9457SAndroid Build Coastguard Worker     .batch_size(5)
765*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(3)
766*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
767*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
768*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
769*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
770*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
771*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
772*4bdc9457SAndroid Build Coastguard Worker }
773*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,setup_changing_height)774*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, setup_changing_height) {
775*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
776*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
777*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
778*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
779*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
780*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(9)
781*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
782*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
783*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
784*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
785*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
786*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
787*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
788*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
789*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(7)
790*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
791*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
792*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
793*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
794*4bdc9457SAndroid Build Coastguard Worker }
795*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,setup_changing_width)796*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, setup_changing_width) {
797*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
798*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
799*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
800*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
801*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
802*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
803*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
804*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
805*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
806*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
807*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
808*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
809*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
810*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
811*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(7)
812*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
813*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
814*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
815*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
816*4bdc9457SAndroid Build Coastguard Worker }
817*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_S8,setup_swap_height_and_width)818*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_S8, setup_swap_height_and_width) {
819*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
820*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
821*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
822*4bdc9457SAndroid Build Coastguard Worker     .input_height(9)
823*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
824*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(8)
825*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
826*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
827*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
828*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
829*4bdc9457SAndroid Build Coastguard Worker     .TestSetupS8();
830*4bdc9457SAndroid Build Coastguard Worker }
831*4bdc9457SAndroid Build Coastguard Worker 
832*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_1xM_pool)833*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_1xM_pool) {
834*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
835*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
836*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
837*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
838*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
839*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
840*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
841*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
842*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
843*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
844*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
845*4bdc9457SAndroid Build Coastguard Worker     }
846*4bdc9457SAndroid Build Coastguard Worker   }
847*4bdc9457SAndroid Build Coastguard Worker }
848*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_1xM_pool_with_padding)849*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_1xM_pool_with_padding) {
850*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
851*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
852*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
853*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
854*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
855*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
856*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
857*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
858*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
859*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
860*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
861*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
862*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
863*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
864*4bdc9457SAndroid Build Coastguard Worker             .TestU8();
865*4bdc9457SAndroid Build Coastguard Worker         }
866*4bdc9457SAndroid Build Coastguard Worker       }
867*4bdc9457SAndroid Build Coastguard Worker     }
868*4bdc9457SAndroid Build Coastguard Worker   }
869*4bdc9457SAndroid Build Coastguard Worker }
870*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_1xM_pool_with_tf_same_padding)871*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_1xM_pool_with_tf_same_padding) {
872*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
873*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
874*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
875*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
876*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
877*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
878*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
879*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
880*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
881*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
882*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
883*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
884*4bdc9457SAndroid Build Coastguard Worker           .TestU8();
885*4bdc9457SAndroid Build Coastguard Worker       }
886*4bdc9457SAndroid Build Coastguard Worker     }
887*4bdc9457SAndroid Build Coastguard Worker   }
888*4bdc9457SAndroid Build Coastguard Worker }
889*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_1xM_pool_with_stride)890*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_1xM_pool_with_stride) {
891*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
892*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
893*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
894*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
895*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
896*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
897*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
898*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
899*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
900*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
901*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
902*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
903*4bdc9457SAndroid Build Coastguard Worker     }
904*4bdc9457SAndroid Build Coastguard Worker   }
905*4bdc9457SAndroid Build Coastguard Worker }
906*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_1xM_pool_with_dilation)907*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_1xM_pool_with_dilation) {
908*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
909*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
910*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
911*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
912*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
913*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
914*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
915*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
916*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
917*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
918*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
919*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
920*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
921*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
922*4bdc9457SAndroid Build Coastguard Worker     }
923*4bdc9457SAndroid Build Coastguard Worker   }
924*4bdc9457SAndroid Build Coastguard Worker }
925*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_Mx1_pool)926*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_Mx1_pool) {
927*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
928*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
929*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
930*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
931*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
932*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
933*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
934*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
935*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
936*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
937*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
938*4bdc9457SAndroid Build Coastguard Worker     }
939*4bdc9457SAndroid Build Coastguard Worker   }
940*4bdc9457SAndroid Build Coastguard Worker }
941*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_Mx1_pool_with_padding)942*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_Mx1_pool_with_padding) {
943*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
944*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
945*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
946*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
947*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
948*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
949*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
950*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
951*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
952*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
953*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
954*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
955*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
956*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
957*4bdc9457SAndroid Build Coastguard Worker             .TestU8();
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 }
963*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_Mx1_pool_with_tf_same_padding)964*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_Mx1_pool_with_tf_same_padding) {
965*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
966*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
967*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
968*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
969*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
970*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
971*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
972*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
973*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
974*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
975*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
976*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
977*4bdc9457SAndroid Build Coastguard Worker           .TestU8();
978*4bdc9457SAndroid Build Coastguard Worker       }
979*4bdc9457SAndroid Build Coastguard Worker     }
980*4bdc9457SAndroid Build Coastguard Worker   }
981*4bdc9457SAndroid Build Coastguard Worker }
982*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_Mx1_pool_with_stride)983*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_Mx1_pool_with_stride) {
984*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
985*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
986*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
987*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
988*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
989*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
990*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
991*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
992*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
993*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
994*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
995*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
996*4bdc9457SAndroid Build Coastguard Worker     }
997*4bdc9457SAndroid Build Coastguard Worker   }
998*4bdc9457SAndroid Build Coastguard Worker }
999*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_Mx1_pool_with_dilation)1000*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_Mx1_pool_with_dilation) {
1001*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1002*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1003*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1004*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1005*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1006*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
1007*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1008*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
1009*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
1010*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1011*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1012*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
1013*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1014*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1015*4bdc9457SAndroid Build Coastguard Worker     }
1016*4bdc9457SAndroid Build Coastguard Worker   }
1017*4bdc9457SAndroid Build Coastguard Worker }
1018*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_pool_with_input_stride)1019*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_pool_with_input_stride) {
1020*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1021*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1022*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1023*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1024*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1025*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1026*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1027*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1028*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1029*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1030*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1031*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1032*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1033*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1034*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1035*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1036*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1037*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1038*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1039*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1040*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1041*4bdc9457SAndroid Build Coastguard Worker     }
1042*4bdc9457SAndroid Build Coastguard Worker   }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_pool_with_output_stride)1045*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_pool_with_output_stride) {
1046*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1047*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1048*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1049*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1050*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1051*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1052*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1053*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1054*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1055*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1056*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1057*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1058*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1059*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1060*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1061*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1062*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1063*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1064*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1065*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1066*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1067*4bdc9457SAndroid Build Coastguard Worker     }
1068*4bdc9457SAndroid Build Coastguard Worker   }
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_pool_with_qmin)1071*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_pool_with_qmin) {
1072*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1073*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1074*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1075*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1076*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1077*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1078*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1079*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1080*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1081*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1082*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1083*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1084*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1085*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1086*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1087*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1088*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1089*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1090*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1091*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1092*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1093*4bdc9457SAndroid Build Coastguard Worker     }
1094*4bdc9457SAndroid Build Coastguard Worker   }
1095*4bdc9457SAndroid Build Coastguard Worker }
1096*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_small_pool_with_qmax)1097*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_small_pool_with_qmax) {
1098*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1099*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1100*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1101*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1102*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1103*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1104*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1105*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1106*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1107*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1108*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1109*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1110*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1111*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1112*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1113*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1114*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1115*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1116*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1117*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1118*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1119*4bdc9457SAndroid Build Coastguard Worker     }
1120*4bdc9457SAndroid Build Coastguard Worker   }
1121*4bdc9457SAndroid Build Coastguard Worker }
1122*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_1xM_pool)1123*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_1xM_pool) {
1124*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1125*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1126*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1127*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1128*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1129*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1130*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1131*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1132*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1133*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1134*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1135*4bdc9457SAndroid Build Coastguard Worker     }
1136*4bdc9457SAndroid Build Coastguard Worker   }
1137*4bdc9457SAndroid Build Coastguard Worker }
1138*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_1xM_pool_with_padding)1139*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_1xM_pool_with_padding) {
1140*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1141*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1142*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1143*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
1144*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
1145*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
1146*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
1147*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
1148*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
1149*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
1150*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
1151*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
1152*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
1153*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1154*4bdc9457SAndroid Build Coastguard Worker             .TestU8();
1155*4bdc9457SAndroid Build Coastguard Worker         }
1156*4bdc9457SAndroid Build Coastguard Worker       }
1157*4bdc9457SAndroid Build Coastguard Worker     }
1158*4bdc9457SAndroid Build Coastguard Worker   }
1159*4bdc9457SAndroid Build Coastguard Worker }
1160*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_1xM_pool_with_tf_same_padding)1161*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_1xM_pool_with_tf_same_padding) {
1162*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1163*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1164*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1165*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
1166*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
1167*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
1168*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
1169*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
1170*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
1171*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
1172*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
1173*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1174*4bdc9457SAndroid Build Coastguard Worker           .TestU8();
1175*4bdc9457SAndroid Build Coastguard Worker       }
1176*4bdc9457SAndroid Build Coastguard Worker     }
1177*4bdc9457SAndroid Build Coastguard Worker   }
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_1xM_pool_with_stride)1180*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_1xM_pool_with_stride) {
1181*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1182*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1183*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1184*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1185*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1186*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1187*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
1188*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1189*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1190*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
1191*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1192*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1193*4bdc9457SAndroid Build Coastguard Worker     }
1194*4bdc9457SAndroid Build Coastguard Worker   }
1195*4bdc9457SAndroid Build Coastguard Worker }
1196*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_1xM_pool_with_dilation)1197*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_1xM_pool_with_dilation) {
1198*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1199*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1200*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1201*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1202*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1203*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1204*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
1205*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
1206*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
1207*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1208*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1209*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
1210*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1211*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1212*4bdc9457SAndroid Build Coastguard Worker     }
1213*4bdc9457SAndroid Build Coastguard Worker   }
1214*4bdc9457SAndroid Build Coastguard Worker }
1215*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_Mx1_pool)1216*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_Mx1_pool) {
1217*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1218*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1219*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1220*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1221*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1222*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1223*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1224*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1225*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1226*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1227*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1228*4bdc9457SAndroid Build Coastguard Worker     }
1229*4bdc9457SAndroid Build Coastguard Worker   }
1230*4bdc9457SAndroid Build Coastguard Worker }
1231*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_Mx1_pool_with_padding)1232*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_Mx1_pool_with_padding) {
1233*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1234*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1235*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1236*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
1237*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
1238*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
1239*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
1240*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
1241*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
1242*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
1243*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
1244*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
1245*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
1246*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1247*4bdc9457SAndroid Build Coastguard Worker             .TestU8();
1248*4bdc9457SAndroid Build Coastguard Worker         }
1249*4bdc9457SAndroid Build Coastguard Worker       }
1250*4bdc9457SAndroid Build Coastguard Worker     }
1251*4bdc9457SAndroid Build Coastguard Worker   }
1252*4bdc9457SAndroid Build Coastguard Worker }
1253*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_Mx1_pool_with_tf_same_padding)1254*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_Mx1_pool_with_tf_same_padding) {
1255*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1256*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1257*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1258*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
1259*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
1260*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
1261*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
1262*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
1263*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
1264*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
1265*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
1266*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1267*4bdc9457SAndroid Build Coastguard Worker           .TestU8();
1268*4bdc9457SAndroid Build Coastguard Worker       }
1269*4bdc9457SAndroid Build Coastguard Worker     }
1270*4bdc9457SAndroid Build Coastguard Worker   }
1271*4bdc9457SAndroid Build Coastguard Worker }
1272*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_Mx1_pool_with_stride)1273*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_Mx1_pool_with_stride) {
1274*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1275*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1276*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1277*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1278*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1279*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
1280*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1281*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1282*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1283*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
1284*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1285*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1286*4bdc9457SAndroid Build Coastguard Worker     }
1287*4bdc9457SAndroid Build Coastguard Worker   }
1288*4bdc9457SAndroid Build Coastguard Worker }
1289*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_Mx1_pool_with_dilation)1290*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_Mx1_pool_with_dilation) {
1291*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1292*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1293*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1294*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1295*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1296*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
1297*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1298*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
1299*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
1300*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1301*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1302*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
1303*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1304*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1305*4bdc9457SAndroid Build Coastguard Worker     }
1306*4bdc9457SAndroid Build Coastguard Worker   }
1307*4bdc9457SAndroid Build Coastguard Worker }
1308*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_pool_with_input_stride)1309*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_pool_with_input_stride) {
1310*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1311*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1312*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1313*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1314*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1315*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1316*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1317*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1318*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1319*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1320*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1321*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1322*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1323*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1324*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1325*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1326*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1327*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1328*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1329*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1330*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1331*4bdc9457SAndroid Build Coastguard Worker     }
1332*4bdc9457SAndroid Build Coastguard Worker   }
1333*4bdc9457SAndroid Build Coastguard Worker }
1334*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_pool_with_output_stride)1335*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_pool_with_output_stride) {
1336*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1337*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1338*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1339*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1340*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1341*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1342*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1343*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1344*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1345*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1346*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1347*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1348*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1349*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1350*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1351*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1352*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1353*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1354*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1355*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1356*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1357*4bdc9457SAndroid Build Coastguard Worker     }
1358*4bdc9457SAndroid Build Coastguard Worker   }
1359*4bdc9457SAndroid Build Coastguard Worker }
1360*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_pool_with_qmin)1361*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_pool_with_qmin) {
1362*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1363*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1364*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1365*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1366*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1367*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1368*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1369*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1370*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1371*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1372*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1373*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1374*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1375*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1376*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1377*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1378*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1379*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1380*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1381*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1382*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1383*4bdc9457SAndroid Build Coastguard Worker     }
1384*4bdc9457SAndroid Build Coastguard Worker   }
1385*4bdc9457SAndroid Build Coastguard Worker }
1386*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,unit_batch_large_pool_with_qmax)1387*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, unit_batch_large_pool_with_qmax) {
1388*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1389*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1390*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1391*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1392*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1393*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1394*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1395*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1396*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1397*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1398*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1399*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1400*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1401*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1402*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1403*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1404*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1405*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1406*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1407*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1408*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1409*4bdc9457SAndroid Build Coastguard Worker     }
1410*4bdc9457SAndroid Build Coastguard Worker   }
1411*4bdc9457SAndroid Build Coastguard Worker }
1412*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_small_pool)1413*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_small_pool) {
1414*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1415*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1416*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1417*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1418*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1419*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1420*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1421*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1422*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1423*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1424*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1425*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1426*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1427*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1428*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1429*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1430*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1431*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1432*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1433*4bdc9457SAndroid Build Coastguard Worker     }
1434*4bdc9457SAndroid Build Coastguard Worker   }
1435*4bdc9457SAndroid Build Coastguard Worker }
1436*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_small_pool_with_input_stride)1437*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_small_pool_with_input_stride) {
1438*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1439*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1440*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1441*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1442*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1443*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1444*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1445*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1446*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1447*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1448*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1449*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1450*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1451*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1452*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1453*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1454*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1455*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1456*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1457*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1458*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1459*4bdc9457SAndroid Build Coastguard Worker     }
1460*4bdc9457SAndroid Build Coastguard Worker   }
1461*4bdc9457SAndroid Build Coastguard Worker }
1462*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_small_pool_with_output_stride)1463*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_small_pool_with_output_stride) {
1464*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1465*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1466*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.u8.maxpool.mr; pool_size++) {
1467*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1468*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1469*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1470*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1471*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1472*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1473*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1474*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1475*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1476*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1477*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1478*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1479*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1480*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1481*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1482*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1483*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1484*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1485*4bdc9457SAndroid Build Coastguard Worker     }
1486*4bdc9457SAndroid Build Coastguard Worker   }
1487*4bdc9457SAndroid Build Coastguard Worker }
1488*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_large_pool)1489*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_large_pool) {
1490*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1491*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1492*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1493*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1494*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1495*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1496*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1497*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1498*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1499*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1500*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1501*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1502*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1503*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1504*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1505*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1506*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1507*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1508*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1509*4bdc9457SAndroid Build Coastguard Worker     }
1510*4bdc9457SAndroid Build Coastguard Worker   }
1511*4bdc9457SAndroid Build Coastguard Worker }
1512*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_large_pool_with_input_stride)1513*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_large_pool_with_input_stride) {
1514*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1515*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1516*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1517*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1518*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1519*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1520*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1521*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1522*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1523*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1524*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1525*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1526*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1527*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1528*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1529*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1530*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1531*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1532*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1533*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1534*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1535*4bdc9457SAndroid Build Coastguard Worker     }
1536*4bdc9457SAndroid Build Coastguard Worker   }
1537*4bdc9457SAndroid Build Coastguard Worker }
1538*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,small_batch_large_pool_with_output_stride)1539*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, small_batch_large_pool_with_output_stride) {
1540*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1541*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1542*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.u8.maxpool.mr + 1; pool_size <= xnn_params.u8.maxpool.mr + xnn_params.u8.maxpool.qr; pool_size++) {
1543*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1544*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1545*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1546*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1547*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1548*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1549*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1550*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1551*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1552*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1553*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
1554*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1555*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1556*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1557*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1558*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1559*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1560*4bdc9457SAndroid Build Coastguard Worker         .TestU8();
1561*4bdc9457SAndroid Build Coastguard Worker     }
1562*4bdc9457SAndroid Build Coastguard Worker   }
1563*4bdc9457SAndroid Build Coastguard Worker }
1564*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,setup_increasing_batch)1565*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, setup_increasing_batch) {
1566*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1567*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1568*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1569*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(5)
1570*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1571*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1572*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1573*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1574*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1575*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1576*4bdc9457SAndroid Build Coastguard Worker }
1577*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,setup_decreasing_batch)1578*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, setup_decreasing_batch) {
1579*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1580*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1581*4bdc9457SAndroid Build Coastguard Worker     .batch_size(5)
1582*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(3)
1583*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1584*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1585*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1586*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1587*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1588*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1589*4bdc9457SAndroid Build Coastguard Worker }
1590*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,setup_changing_height)1591*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, setup_changing_height) {
1592*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1593*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1594*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1595*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1596*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1597*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(9)
1598*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1599*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1600*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1601*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1602*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1603*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1604*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1605*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1606*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(7)
1607*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1608*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1609*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1610*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1611*4bdc9457SAndroid Build Coastguard Worker }
1612*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,setup_changing_width)1613*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, setup_changing_width) {
1614*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1615*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1616*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1617*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1618*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1619*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
1620*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1621*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1622*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1623*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1624*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1625*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1626*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
1627*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1628*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(7)
1629*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1630*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1631*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1632*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1633*4bdc9457SAndroid Build Coastguard Worker }
1634*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_U8,setup_swap_height_and_width)1635*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_U8, setup_swap_height_and_width) {
1636*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1637*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
1638*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
1639*4bdc9457SAndroid Build Coastguard Worker     .input_height(9)
1640*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
1641*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(8)
1642*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
1643*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
1644*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
1645*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
1646*4bdc9457SAndroid Build Coastguard Worker     .TestSetupU8();
1647*4bdc9457SAndroid Build Coastguard Worker }
1648*4bdc9457SAndroid Build Coastguard Worker 
1649*4bdc9457SAndroid Build Coastguard Worker 
1650*4bdc9457SAndroid Build Coastguard Worker #ifndef XNN_EXCLUDE_F16_TESTS
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_1xM_pool)1651*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_1xM_pool) {
1652*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1653*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1654*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1655*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1656*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1657*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1658*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1659*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1660*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1661*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1662*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1663*4bdc9457SAndroid Build Coastguard Worker     }
1664*4bdc9457SAndroid Build Coastguard Worker   }
1665*4bdc9457SAndroid Build Coastguard Worker }
1666*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_1xM_pool_with_padding)1667*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_1xM_pool_with_padding) {
1668*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1669*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1670*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1671*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
1672*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
1673*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
1674*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
1675*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
1676*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
1677*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
1678*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
1679*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
1680*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
1681*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1682*4bdc9457SAndroid Build Coastguard Worker             .TestF16();
1683*4bdc9457SAndroid Build Coastguard Worker         }
1684*4bdc9457SAndroid Build Coastguard Worker       }
1685*4bdc9457SAndroid Build Coastguard Worker     }
1686*4bdc9457SAndroid Build Coastguard Worker   }
1687*4bdc9457SAndroid Build Coastguard Worker }
1688*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_1xM_pool_with_tf_same_padding)1689*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_1xM_pool_with_tf_same_padding) {
1690*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1691*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1692*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1693*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
1694*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
1695*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
1696*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
1697*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
1698*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
1699*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
1700*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
1701*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1702*4bdc9457SAndroid Build Coastguard Worker           .TestF16();
1703*4bdc9457SAndroid Build Coastguard Worker       }
1704*4bdc9457SAndroid Build Coastguard Worker     }
1705*4bdc9457SAndroid Build Coastguard Worker   }
1706*4bdc9457SAndroid Build Coastguard Worker }
1707*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_1xM_pool_with_stride)1708*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_1xM_pool_with_stride) {
1709*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1710*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1711*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1712*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1713*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1714*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1715*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
1716*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1717*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1718*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
1719*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1720*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1721*4bdc9457SAndroid Build Coastguard Worker     }
1722*4bdc9457SAndroid Build Coastguard Worker   }
1723*4bdc9457SAndroid Build Coastguard Worker }
1724*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_1xM_pool_with_dilation)1725*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_1xM_pool_with_dilation) {
1726*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1727*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1728*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1729*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1730*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1731*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1732*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
1733*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
1734*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
1735*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1736*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1737*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
1738*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1739*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1740*4bdc9457SAndroid Build Coastguard Worker     }
1741*4bdc9457SAndroid Build Coastguard Worker   }
1742*4bdc9457SAndroid Build Coastguard Worker }
1743*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_Mx1_pool)1744*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_Mx1_pool) {
1745*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1746*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1747*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1748*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1749*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1750*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1751*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1752*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1753*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1754*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1755*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1756*4bdc9457SAndroid Build Coastguard Worker     }
1757*4bdc9457SAndroid Build Coastguard Worker   }
1758*4bdc9457SAndroid Build Coastguard Worker }
1759*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_Mx1_pool_with_padding)1760*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_Mx1_pool_with_padding) {
1761*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1762*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1763*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1764*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
1765*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
1766*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
1767*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
1768*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
1769*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
1770*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
1771*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
1772*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
1773*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
1774*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1775*4bdc9457SAndroid Build Coastguard Worker             .TestF16();
1776*4bdc9457SAndroid Build Coastguard Worker         }
1777*4bdc9457SAndroid Build Coastguard Worker       }
1778*4bdc9457SAndroid Build Coastguard Worker     }
1779*4bdc9457SAndroid Build Coastguard Worker   }
1780*4bdc9457SAndroid Build Coastguard Worker }
1781*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_Mx1_pool_with_tf_same_padding)1782*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_Mx1_pool_with_tf_same_padding) {
1783*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1784*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1785*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1786*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
1787*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
1788*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
1789*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
1790*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
1791*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
1792*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
1793*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
1794*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1795*4bdc9457SAndroid Build Coastguard Worker           .TestF16();
1796*4bdc9457SAndroid Build Coastguard Worker       }
1797*4bdc9457SAndroid Build Coastguard Worker     }
1798*4bdc9457SAndroid Build Coastguard Worker   }
1799*4bdc9457SAndroid Build Coastguard Worker }
1800*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_Mx1_pool_with_stride)1801*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_Mx1_pool_with_stride) {
1802*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1803*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1804*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1805*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1806*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1807*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
1808*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1809*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1810*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1811*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
1812*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1813*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1814*4bdc9457SAndroid Build Coastguard Worker     }
1815*4bdc9457SAndroid Build Coastguard Worker   }
1816*4bdc9457SAndroid Build Coastguard Worker }
1817*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_Mx1_pool_with_dilation)1818*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_Mx1_pool_with_dilation) {
1819*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1820*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1821*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1822*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1823*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1824*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
1825*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1826*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
1827*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
1828*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1829*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1830*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
1831*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1832*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1833*4bdc9457SAndroid Build Coastguard Worker     }
1834*4bdc9457SAndroid Build Coastguard Worker   }
1835*4bdc9457SAndroid Build Coastguard Worker }
1836*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_pool_with_input_stride)1837*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_pool_with_input_stride) {
1838*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1839*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1840*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1841*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1842*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1843*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1844*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1845*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1846*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1847*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1848*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1849*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1850*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1851*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1852*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1853*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1854*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1855*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1856*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1857*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
1858*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1859*4bdc9457SAndroid Build Coastguard Worker     }
1860*4bdc9457SAndroid Build Coastguard Worker   }
1861*4bdc9457SAndroid Build Coastguard Worker }
1862*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_pool_with_output_stride)1863*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_pool_with_output_stride) {
1864*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1865*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1866*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1867*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1868*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1869*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1870*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1871*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1872*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1873*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1874*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1875*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1876*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1877*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1878*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1879*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1880*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1881*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1882*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1883*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
1884*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1885*4bdc9457SAndroid Build Coastguard Worker     }
1886*4bdc9457SAndroid Build Coastguard Worker   }
1887*4bdc9457SAndroid Build Coastguard Worker }
1888*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_pool_with_qmin)1889*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_pool_with_qmin) {
1890*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1891*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1892*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1893*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1894*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1895*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1896*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1897*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1898*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1899*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1900*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1901*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1902*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1903*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1904*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1905*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1906*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1907*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1908*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1909*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
1910*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1911*4bdc9457SAndroid Build Coastguard Worker     }
1912*4bdc9457SAndroid Build Coastguard Worker   }
1913*4bdc9457SAndroid Build Coastguard Worker }
1914*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_small_pool_with_qmax)1915*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_small_pool_with_qmax) {
1916*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1917*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1918*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
1919*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1920*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1921*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
1922*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
1923*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
1924*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
1925*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1926*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1927*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1928*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1929*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1930*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1931*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1932*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1933*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1934*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1935*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
1936*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1937*4bdc9457SAndroid Build Coastguard Worker     }
1938*4bdc9457SAndroid Build Coastguard Worker   }
1939*4bdc9457SAndroid Build Coastguard Worker }
1940*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_1xM_pool)1941*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_1xM_pool) {
1942*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1943*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1944*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
1945*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
1946*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
1947*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
1948*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
1949*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
1950*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
1951*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
1952*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
1953*4bdc9457SAndroid Build Coastguard Worker     }
1954*4bdc9457SAndroid Build Coastguard Worker   }
1955*4bdc9457SAndroid Build Coastguard Worker }
1956*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_1xM_pool_with_padding)1957*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_1xM_pool_with_padding) {
1958*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1959*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1960*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
1961*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
1962*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
1963*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
1964*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
1965*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
1966*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
1967*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
1968*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
1969*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
1970*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
1971*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
1972*4bdc9457SAndroid Build Coastguard Worker             .TestF16();
1973*4bdc9457SAndroid Build Coastguard Worker         }
1974*4bdc9457SAndroid Build Coastguard Worker       }
1975*4bdc9457SAndroid Build Coastguard Worker     }
1976*4bdc9457SAndroid Build Coastguard Worker   }
1977*4bdc9457SAndroid Build Coastguard Worker }
1978*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_1xM_pool_with_tf_same_padding)1979*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_1xM_pool_with_tf_same_padding) {
1980*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1981*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
1982*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
1983*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
1984*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
1985*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
1986*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
1987*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
1988*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
1989*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
1990*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
1991*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
1992*4bdc9457SAndroid Build Coastguard Worker           .TestF16();
1993*4bdc9457SAndroid Build Coastguard Worker       }
1994*4bdc9457SAndroid Build Coastguard Worker     }
1995*4bdc9457SAndroid Build Coastguard Worker   }
1996*4bdc9457SAndroid Build Coastguard Worker }
1997*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_1xM_pool_with_stride)1998*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_1xM_pool_with_stride) {
1999*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2000*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2001*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2002*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2003*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2004*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2005*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
2006*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2007*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2008*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
2009*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2010*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2011*4bdc9457SAndroid Build Coastguard Worker     }
2012*4bdc9457SAndroid Build Coastguard Worker   }
2013*4bdc9457SAndroid Build Coastguard Worker }
2014*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_1xM_pool_with_dilation)2015*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_1xM_pool_with_dilation) {
2016*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2017*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2018*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2019*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2020*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2021*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2022*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
2023*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
2024*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
2025*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2026*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2027*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
2028*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2029*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2030*4bdc9457SAndroid Build Coastguard Worker     }
2031*4bdc9457SAndroid Build Coastguard Worker   }
2032*4bdc9457SAndroid Build Coastguard Worker }
2033*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_Mx1_pool)2034*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_Mx1_pool) {
2035*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2036*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2037*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2038*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2039*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2040*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2041*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2042*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2043*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2044*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2045*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2046*4bdc9457SAndroid Build Coastguard Worker     }
2047*4bdc9457SAndroid Build Coastguard Worker   }
2048*4bdc9457SAndroid Build Coastguard Worker }
2049*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_Mx1_pool_with_padding)2050*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_Mx1_pool_with_padding) {
2051*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2052*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2053*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2054*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
2055*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
2056*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
2057*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
2058*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
2059*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
2060*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
2061*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
2062*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
2063*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
2064*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2065*4bdc9457SAndroid Build Coastguard Worker             .TestF16();
2066*4bdc9457SAndroid Build Coastguard Worker         }
2067*4bdc9457SAndroid Build Coastguard Worker       }
2068*4bdc9457SAndroid Build Coastguard Worker     }
2069*4bdc9457SAndroid Build Coastguard Worker   }
2070*4bdc9457SAndroid Build Coastguard Worker }
2071*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_Mx1_pool_with_tf_same_padding)2072*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_Mx1_pool_with_tf_same_padding) {
2073*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2074*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2075*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2076*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
2077*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
2078*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
2079*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
2080*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
2081*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
2082*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
2083*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
2084*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2085*4bdc9457SAndroid Build Coastguard Worker           .TestF16();
2086*4bdc9457SAndroid Build Coastguard Worker       }
2087*4bdc9457SAndroid Build Coastguard Worker     }
2088*4bdc9457SAndroid Build Coastguard Worker   }
2089*4bdc9457SAndroid Build Coastguard Worker }
2090*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_Mx1_pool_with_stride)2091*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_Mx1_pool_with_stride) {
2092*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2093*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2094*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2095*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2096*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2097*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
2098*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2099*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2100*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2101*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
2102*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2103*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2104*4bdc9457SAndroid Build Coastguard Worker     }
2105*4bdc9457SAndroid Build Coastguard Worker   }
2106*4bdc9457SAndroid Build Coastguard Worker }
2107*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_Mx1_pool_with_dilation)2108*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_Mx1_pool_with_dilation) {
2109*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2110*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2111*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2112*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2113*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2114*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
2115*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2116*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
2117*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
2118*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2119*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2120*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
2121*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2122*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2123*4bdc9457SAndroid Build Coastguard Worker     }
2124*4bdc9457SAndroid Build Coastguard Worker   }
2125*4bdc9457SAndroid Build Coastguard Worker }
2126*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_pool_with_input_stride)2127*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_pool_with_input_stride) {
2128*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2129*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2130*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2131*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2132*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2133*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2134*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2135*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2136*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2137*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2138*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2139*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2140*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2141*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2142*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2143*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2144*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2145*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2146*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2147*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2148*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2149*4bdc9457SAndroid Build Coastguard Worker     }
2150*4bdc9457SAndroid Build Coastguard Worker   }
2151*4bdc9457SAndroid Build Coastguard Worker }
2152*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_pool_with_output_stride)2153*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_pool_with_output_stride) {
2154*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2155*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2156*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2157*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2158*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2159*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2160*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2161*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2162*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2163*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2164*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2165*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2166*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2167*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2168*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2169*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2170*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2171*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2172*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2173*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2174*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2175*4bdc9457SAndroid Build Coastguard Worker     }
2176*4bdc9457SAndroid Build Coastguard Worker   }
2177*4bdc9457SAndroid Build Coastguard Worker }
2178*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_pool_with_qmin)2179*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_pool_with_qmin) {
2180*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2181*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2182*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2183*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2184*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2185*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2186*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2187*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2188*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2189*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2190*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
2191*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2192*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2193*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2194*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2195*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2196*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2197*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2198*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2199*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
2200*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2201*4bdc9457SAndroid Build Coastguard Worker     }
2202*4bdc9457SAndroid Build Coastguard Worker   }
2203*4bdc9457SAndroid Build Coastguard Worker }
2204*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,unit_batch_large_pool_with_qmax)2205*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, unit_batch_large_pool_with_qmax) {
2206*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2207*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2208*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2209*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2210*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2211*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2212*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2213*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2214*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2215*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2216*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
2217*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2218*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2219*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2220*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2221*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2222*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2223*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2224*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2225*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
2226*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2227*4bdc9457SAndroid Build Coastguard Worker     }
2228*4bdc9457SAndroid Build Coastguard Worker   }
2229*4bdc9457SAndroid Build Coastguard Worker }
2230*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_small_pool)2231*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_small_pool) {
2232*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2233*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2234*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2235*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2236*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2237*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2238*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2239*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2240*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2241*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2242*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2243*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2244*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2245*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2246*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2247*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2248*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2249*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2250*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2251*4bdc9457SAndroid Build Coastguard Worker     }
2252*4bdc9457SAndroid Build Coastguard Worker   }
2253*4bdc9457SAndroid Build Coastguard Worker }
2254*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_small_pool_with_input_stride)2255*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_small_pool_with_input_stride) {
2256*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2257*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2258*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2259*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2260*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2261*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2262*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2263*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2264*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2265*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2266*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2267*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2268*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2269*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2270*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2271*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2272*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2273*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2274*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2275*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2276*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2277*4bdc9457SAndroid Build Coastguard Worker     }
2278*4bdc9457SAndroid Build Coastguard Worker   }
2279*4bdc9457SAndroid Build Coastguard Worker }
2280*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_small_pool_with_output_stride)2281*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_small_pool_with_output_stride) {
2282*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2283*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2284*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2285*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2286*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2287*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2288*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2289*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2290*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2291*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2292*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2293*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2294*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2295*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2296*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2297*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2298*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2299*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2300*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2301*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2302*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2303*4bdc9457SAndroid Build Coastguard Worker     }
2304*4bdc9457SAndroid Build Coastguard Worker   }
2305*4bdc9457SAndroid Build Coastguard Worker }
2306*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_large_pool)2307*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_large_pool) {
2308*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2309*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2310*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2311*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2312*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2313*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2314*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2315*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2316*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2317*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2318*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2319*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2320*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2321*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2322*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2323*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2324*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2325*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2326*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2327*4bdc9457SAndroid Build Coastguard Worker     }
2328*4bdc9457SAndroid Build Coastguard Worker   }
2329*4bdc9457SAndroid Build Coastguard Worker }
2330*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_large_pool_with_input_stride)2331*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_large_pool_with_input_stride) {
2332*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2333*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2334*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2335*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2336*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2337*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2338*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2339*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2340*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2341*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2342*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2343*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2344*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2345*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2346*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2347*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2348*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2349*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2350*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2351*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2352*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2353*4bdc9457SAndroid Build Coastguard Worker     }
2354*4bdc9457SAndroid Build Coastguard Worker   }
2355*4bdc9457SAndroid Build Coastguard Worker }
2356*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,small_batch_large_pool_with_output_stride)2357*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, small_batch_large_pool_with_output_stride) {
2358*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2359*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2360*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2361*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2362*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2363*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2364*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2365*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2366*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2367*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2368*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2369*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2370*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2371*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
2372*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2373*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2374*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2375*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2376*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2377*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2378*4bdc9457SAndroid Build Coastguard Worker         .TestF16();
2379*4bdc9457SAndroid Build Coastguard Worker     }
2380*4bdc9457SAndroid Build Coastguard Worker   }
2381*4bdc9457SAndroid Build Coastguard Worker }
2382*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,setup_increasing_batch)2383*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, setup_increasing_batch) {
2384*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2385*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2386*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2387*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(5)
2388*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2389*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2390*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2391*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2392*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2393*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2394*4bdc9457SAndroid Build Coastguard Worker }
2395*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,setup_decreasing_batch)2396*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, setup_decreasing_batch) {
2397*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2398*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2399*4bdc9457SAndroid Build Coastguard Worker     .batch_size(5)
2400*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(3)
2401*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2402*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2403*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2404*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2405*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2406*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2407*4bdc9457SAndroid Build Coastguard Worker }
2408*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,setup_changing_height)2409*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, setup_changing_height) {
2410*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2411*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2412*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2413*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2414*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2415*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(9)
2416*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2417*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2418*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2419*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2420*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2421*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2422*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2423*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2424*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(7)
2425*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2426*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2427*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2428*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2429*4bdc9457SAndroid Build Coastguard Worker }
2430*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,setup_changing_width)2431*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, setup_changing_width) {
2432*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2433*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2434*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2435*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2436*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2437*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
2438*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2439*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2440*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2441*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2442*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2443*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2444*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
2445*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2446*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(7)
2447*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2448*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2449*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2450*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2451*4bdc9457SAndroid Build Coastguard Worker }
2452*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F16,setup_swap_height_and_width)2453*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F16, setup_swap_height_and_width) {
2454*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2455*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
2456*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
2457*4bdc9457SAndroid Build Coastguard Worker     .input_height(9)
2458*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
2459*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(8)
2460*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
2461*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
2462*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
2463*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
2464*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF16();
2465*4bdc9457SAndroid Build Coastguard Worker }
2466*4bdc9457SAndroid Build Coastguard Worker #endif  // XNN_EXCLUDE_F16_TESTS
2467*4bdc9457SAndroid Build Coastguard Worker 
2468*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_1xM_pool)2469*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_1xM_pool) {
2470*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2471*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2472*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2473*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2474*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2475*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2476*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2477*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2478*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2479*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2480*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2481*4bdc9457SAndroid Build Coastguard Worker     }
2482*4bdc9457SAndroid Build Coastguard Worker   }
2483*4bdc9457SAndroid Build Coastguard Worker }
2484*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_1xM_pool_with_padding)2485*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_1xM_pool_with_padding) {
2486*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2487*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2488*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2489*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
2490*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
2491*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
2492*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
2493*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
2494*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
2495*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
2496*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
2497*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
2498*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
2499*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2500*4bdc9457SAndroid Build Coastguard Worker             .TestF32();
2501*4bdc9457SAndroid Build Coastguard Worker         }
2502*4bdc9457SAndroid Build Coastguard Worker       }
2503*4bdc9457SAndroid Build Coastguard Worker     }
2504*4bdc9457SAndroid Build Coastguard Worker   }
2505*4bdc9457SAndroid Build Coastguard Worker }
2506*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_1xM_pool_with_tf_same_padding)2507*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_1xM_pool_with_tf_same_padding) {
2508*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2509*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2510*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 3; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2511*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
2512*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
2513*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
2514*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
2515*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
2516*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
2517*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
2518*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
2519*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2520*4bdc9457SAndroid Build Coastguard Worker           .TestF32();
2521*4bdc9457SAndroid Build Coastguard Worker       }
2522*4bdc9457SAndroid Build Coastguard Worker     }
2523*4bdc9457SAndroid Build Coastguard Worker   }
2524*4bdc9457SAndroid Build Coastguard Worker }
2525*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_1xM_pool_with_stride)2526*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_1xM_pool_with_stride) {
2527*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2528*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2529*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2530*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2531*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2532*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2533*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
2534*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2535*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2536*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
2537*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2538*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2539*4bdc9457SAndroid Build Coastguard Worker     }
2540*4bdc9457SAndroid Build Coastguard Worker   }
2541*4bdc9457SAndroid Build Coastguard Worker }
2542*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_1xM_pool_with_dilation)2543*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_1xM_pool_with_dilation) {
2544*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2545*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2546*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2547*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2548*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2549*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2550*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
2551*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
2552*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
2553*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2554*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2555*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
2556*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2557*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2558*4bdc9457SAndroid Build Coastguard Worker     }
2559*4bdc9457SAndroid Build Coastguard Worker   }
2560*4bdc9457SAndroid Build Coastguard Worker }
2561*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_Mx1_pool)2562*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_Mx1_pool) {
2563*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2564*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2565*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2566*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2567*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2568*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2569*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2570*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2571*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2572*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2573*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2574*4bdc9457SAndroid Build Coastguard Worker     }
2575*4bdc9457SAndroid Build Coastguard Worker   }
2576*4bdc9457SAndroid Build Coastguard Worker }
2577*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_Mx1_pool_with_padding)2578*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_Mx1_pool_with_padding) {
2579*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2580*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2581*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2582*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
2583*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
2584*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
2585*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
2586*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
2587*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
2588*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
2589*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
2590*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
2591*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
2592*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2593*4bdc9457SAndroid Build Coastguard Worker             .TestF32();
2594*4bdc9457SAndroid Build Coastguard Worker         }
2595*4bdc9457SAndroid Build Coastguard Worker       }
2596*4bdc9457SAndroid Build Coastguard Worker     }
2597*4bdc9457SAndroid Build Coastguard Worker   }
2598*4bdc9457SAndroid Build Coastguard Worker }
2599*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_Mx1_pool_with_tf_same_padding)2600*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_Mx1_pool_with_tf_same_padding) {
2601*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2602*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2603*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2604*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
2605*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
2606*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
2607*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
2608*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
2609*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
2610*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
2611*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
2612*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2613*4bdc9457SAndroid Build Coastguard Worker           .TestF32();
2614*4bdc9457SAndroid Build Coastguard Worker       }
2615*4bdc9457SAndroid Build Coastguard Worker     }
2616*4bdc9457SAndroid Build Coastguard Worker   }
2617*4bdc9457SAndroid Build Coastguard Worker }
2618*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_Mx1_pool_with_stride)2619*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_Mx1_pool_with_stride) {
2620*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2621*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2622*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2623*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2624*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2625*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
2626*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2627*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2628*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2629*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
2630*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2631*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2632*4bdc9457SAndroid Build Coastguard Worker     }
2633*4bdc9457SAndroid Build Coastguard Worker   }
2634*4bdc9457SAndroid Build Coastguard Worker }
2635*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_Mx1_pool_with_dilation)2636*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_Mx1_pool_with_dilation) {
2637*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2638*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2639*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2640*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2641*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2642*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
2643*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2644*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
2645*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
2646*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2647*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2648*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
2649*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2650*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2651*4bdc9457SAndroid Build Coastguard Worker     }
2652*4bdc9457SAndroid Build Coastguard Worker   }
2653*4bdc9457SAndroid Build Coastguard Worker }
2654*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_pool_with_input_stride)2655*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_pool_with_input_stride) {
2656*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2657*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2658*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2659*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2660*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2661*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2662*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2663*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2664*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2665*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2666*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2667*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2668*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2669*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2670*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2671*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2672*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2673*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2674*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2675*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2676*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2677*4bdc9457SAndroid Build Coastguard Worker     }
2678*4bdc9457SAndroid Build Coastguard Worker   }
2679*4bdc9457SAndroid Build Coastguard Worker }
2680*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_pool_with_output_stride)2681*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_pool_with_output_stride) {
2682*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2683*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2684*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2685*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2686*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2687*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2688*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2689*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2690*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2691*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2692*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2693*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2694*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2695*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2696*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2697*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2698*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2699*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2700*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2701*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2702*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2703*4bdc9457SAndroid Build Coastguard Worker     }
2704*4bdc9457SAndroid Build Coastguard Worker   }
2705*4bdc9457SAndroid Build Coastguard Worker }
2706*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_pool_with_qmin)2707*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_pool_with_qmin) {
2708*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2709*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2710*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2711*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2712*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2713*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2714*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2715*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2716*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2717*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2718*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
2719*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2720*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2721*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2722*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2723*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2724*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2725*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2726*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2727*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
2728*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2729*4bdc9457SAndroid Build Coastguard Worker     }
2730*4bdc9457SAndroid Build Coastguard Worker   }
2731*4bdc9457SAndroid Build Coastguard Worker }
2732*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_small_pool_with_qmax)2733*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_small_pool_with_qmax) {
2734*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2735*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2736*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
2737*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2738*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2739*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2740*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2741*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2742*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2743*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2744*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
2745*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2746*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2747*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2748*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2749*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2750*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2751*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2752*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2753*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
2754*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2755*4bdc9457SAndroid Build Coastguard Worker     }
2756*4bdc9457SAndroid Build Coastguard Worker   }
2757*4bdc9457SAndroid Build Coastguard Worker }
2758*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_1xM_pool)2759*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_1xM_pool) {
2760*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2761*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2762*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2763*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2764*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2765*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2766*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2767*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2768*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2769*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2770*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2771*4bdc9457SAndroid Build Coastguard Worker     }
2772*4bdc9457SAndroid Build Coastguard Worker   }
2773*4bdc9457SAndroid Build Coastguard Worker }
2774*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_1xM_pool_with_padding)2775*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_1xM_pool_with_padding) {
2776*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2777*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2778*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2779*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
2780*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
2781*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
2782*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
2783*4bdc9457SAndroid Build Coastguard Worker             .input_height(2)
2784*4bdc9457SAndroid Build Coastguard Worker             .input_width(pool_size + 2)
2785*4bdc9457SAndroid Build Coastguard Worker             .padding_left(padding_left)
2786*4bdc9457SAndroid Build Coastguard Worker             .padding_right(padding_right)
2787*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(1)
2788*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(pool_size)
2789*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2790*4bdc9457SAndroid Build Coastguard Worker             .TestF32();
2791*4bdc9457SAndroid Build Coastguard Worker         }
2792*4bdc9457SAndroid Build Coastguard Worker       }
2793*4bdc9457SAndroid Build Coastguard Worker     }
2794*4bdc9457SAndroid Build Coastguard Worker   }
2795*4bdc9457SAndroid Build Coastguard Worker }
2796*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_1xM_pool_with_tf_same_padding)2797*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_1xM_pool_with_tf_same_padding) {
2798*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2799*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2800*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2801*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_width = pool_size; input_width <= pool_size * 2; input_width++) {
2802*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
2803*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
2804*4bdc9457SAndroid Build Coastguard Worker           .input_height(2)
2805*4bdc9457SAndroid Build Coastguard Worker           .input_width(input_width)
2806*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
2807*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(1)
2808*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(pool_size)
2809*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2810*4bdc9457SAndroid Build Coastguard Worker           .TestF32();
2811*4bdc9457SAndroid Build Coastguard Worker       }
2812*4bdc9457SAndroid Build Coastguard Worker     }
2813*4bdc9457SAndroid Build Coastguard Worker   }
2814*4bdc9457SAndroid Build Coastguard Worker }
2815*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_1xM_pool_with_stride)2816*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_1xM_pool_with_stride) {
2817*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2818*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2819*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2820*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2821*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2822*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2823*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 4)
2824*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2825*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2826*4bdc9457SAndroid Build Coastguard Worker         .stride_width(2)
2827*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2828*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2829*4bdc9457SAndroid Build Coastguard Worker     }
2830*4bdc9457SAndroid Build Coastguard Worker   }
2831*4bdc9457SAndroid Build Coastguard Worker }
2832*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_1xM_pool_with_dilation)2833*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_1xM_pool_with_dilation) {
2834*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2835*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2836*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2837*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2838*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2839*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2840*4bdc9457SAndroid Build Coastguard Worker         .input_width(2 * pool_size + 1)
2841*4bdc9457SAndroid Build Coastguard Worker         .padding_left(1)
2842*4bdc9457SAndroid Build Coastguard Worker         .padding_right(1)
2843*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2844*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2845*4bdc9457SAndroid Build Coastguard Worker         .dilation_width(2)
2846*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2847*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2848*4bdc9457SAndroid Build Coastguard Worker     }
2849*4bdc9457SAndroid Build Coastguard Worker   }
2850*4bdc9457SAndroid Build Coastguard Worker }
2851*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_Mx1_pool)2852*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_Mx1_pool) {
2853*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2854*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2855*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2856*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2857*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2858*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2859*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2860*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2861*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2862*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2863*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2864*4bdc9457SAndroid Build Coastguard Worker     }
2865*4bdc9457SAndroid Build Coastguard Worker   }
2866*4bdc9457SAndroid Build Coastguard Worker }
2867*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_Mx1_pool_with_padding)2868*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_Mx1_pool_with_padding) {
2869*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2870*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2871*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2872*4bdc9457SAndroid Build Coastguard Worker       for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
2873*4bdc9457SAndroid Build Coastguard Worker         for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
2874*4bdc9457SAndroid Build Coastguard Worker           MaxPoolingOperatorTester()
2875*4bdc9457SAndroid Build Coastguard Worker             .batch_size(1)
2876*4bdc9457SAndroid Build Coastguard Worker             .input_height(pool_size + 1)
2877*4bdc9457SAndroid Build Coastguard Worker             .input_width(3)
2878*4bdc9457SAndroid Build Coastguard Worker             .padding_top(padding_top)
2879*4bdc9457SAndroid Build Coastguard Worker             .padding_bottom(padding_bottom)
2880*4bdc9457SAndroid Build Coastguard Worker             .pooling_height(pool_size)
2881*4bdc9457SAndroid Build Coastguard Worker             .pooling_width(1)
2882*4bdc9457SAndroid Build Coastguard Worker             .channels(channels)
2883*4bdc9457SAndroid Build Coastguard Worker             .TestF32();
2884*4bdc9457SAndroid Build Coastguard Worker         }
2885*4bdc9457SAndroid Build Coastguard Worker       }
2886*4bdc9457SAndroid Build Coastguard Worker     }
2887*4bdc9457SAndroid Build Coastguard Worker   }
2888*4bdc9457SAndroid Build Coastguard Worker }
2889*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_Mx1_pool_with_tf_same_padding)2890*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_Mx1_pool_with_tf_same_padding) {
2891*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2892*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2893*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2894*4bdc9457SAndroid Build Coastguard Worker       for (size_t input_height = pool_size; input_height <= pool_size * 2; input_height++) {
2895*4bdc9457SAndroid Build Coastguard Worker         MaxPoolingOperatorTester()
2896*4bdc9457SAndroid Build Coastguard Worker           .batch_size(1)
2897*4bdc9457SAndroid Build Coastguard Worker           .input_height(input_height)
2898*4bdc9457SAndroid Build Coastguard Worker           .input_width(3)
2899*4bdc9457SAndroid Build Coastguard Worker           .padding_tf_same(true)
2900*4bdc9457SAndroid Build Coastguard Worker           .pooling_height(pool_size)
2901*4bdc9457SAndroid Build Coastguard Worker           .pooling_width(1)
2902*4bdc9457SAndroid Build Coastguard Worker           .channels(channels)
2903*4bdc9457SAndroid Build Coastguard Worker           .TestF32();
2904*4bdc9457SAndroid Build Coastguard Worker       }
2905*4bdc9457SAndroid Build Coastguard Worker     }
2906*4bdc9457SAndroid Build Coastguard Worker   }
2907*4bdc9457SAndroid Build Coastguard Worker }
2908*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_Mx1_pool_with_stride)2909*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_Mx1_pool_with_stride) {
2910*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2911*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2912*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2913*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2914*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2915*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 3)
2916*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2917*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2918*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2919*4bdc9457SAndroid Build Coastguard Worker         .stride_height(2)
2920*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2921*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2922*4bdc9457SAndroid Build Coastguard Worker     }
2923*4bdc9457SAndroid Build Coastguard Worker   }
2924*4bdc9457SAndroid Build Coastguard Worker }
2925*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_Mx1_pool_with_dilation)2926*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_Mx1_pool_with_dilation) {
2927*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2928*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2929*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2930*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2931*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2932*4bdc9457SAndroid Build Coastguard Worker         .input_height(2 * pool_size)
2933*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2934*4bdc9457SAndroid Build Coastguard Worker         .padding_top(1)
2935*4bdc9457SAndroid Build Coastguard Worker         .padding_bottom(1)
2936*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2937*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2938*4bdc9457SAndroid Build Coastguard Worker         .dilation_height(2)
2939*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2940*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2941*4bdc9457SAndroid Build Coastguard Worker     }
2942*4bdc9457SAndroid Build Coastguard Worker   }
2943*4bdc9457SAndroid Build Coastguard Worker }
2944*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_pool_with_input_stride)2945*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_pool_with_input_stride) {
2946*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2947*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2948*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2949*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2950*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2951*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2952*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2953*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2954*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2955*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2956*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2957*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2958*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2959*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2960*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2961*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2962*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2963*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2964*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2965*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
2966*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2967*4bdc9457SAndroid Build Coastguard Worker     }
2968*4bdc9457SAndroid Build Coastguard Worker   }
2969*4bdc9457SAndroid Build Coastguard Worker }
2970*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_pool_with_output_stride)2971*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_pool_with_output_stride) {
2972*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2973*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
2974*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
2975*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2976*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2977*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
2978*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
2979*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
2980*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
2981*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2982*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2983*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2984*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
2985*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
2986*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
2987*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
2988*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
2989*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
2990*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
2991*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
2992*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
2993*4bdc9457SAndroid Build Coastguard Worker     }
2994*4bdc9457SAndroid Build Coastguard Worker   }
2995*4bdc9457SAndroid Build Coastguard Worker }
2996*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_pool_with_qmin)2997*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_pool_with_qmin) {
2998*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2999*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3000*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
3001*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3002*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
3003*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3004*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3005*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3006*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3007*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3008*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
3009*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3010*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3011*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
3012*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3013*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3014*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3015*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3016*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3017*4bdc9457SAndroid Build Coastguard Worker         .qmin(192)
3018*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3019*4bdc9457SAndroid Build Coastguard Worker     }
3020*4bdc9457SAndroid Build Coastguard Worker   }
3021*4bdc9457SAndroid Build Coastguard Worker }
3022*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,unit_batch_large_pool_with_qmax)3023*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, unit_batch_large_pool_with_qmax) {
3024*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3025*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3026*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
3027*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3028*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
3029*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3030*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3031*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3032*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3033*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3034*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
3035*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3036*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3037*4bdc9457SAndroid Build Coastguard Worker         .batch_size(1)
3038*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3039*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3040*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3041*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3042*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3043*4bdc9457SAndroid Build Coastguard Worker         .qmax(192)
3044*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3045*4bdc9457SAndroid Build Coastguard Worker     }
3046*4bdc9457SAndroid Build Coastguard Worker   }
3047*4bdc9457SAndroid Build Coastguard Worker }
3048*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_small_pool)3049*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_small_pool) {
3050*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3051*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3052*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
3053*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3054*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3055*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3056*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3057*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3058*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3059*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3060*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3061*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3062*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3063*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3064*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3065*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3066*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3067*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3068*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3069*4bdc9457SAndroid Build Coastguard Worker     }
3070*4bdc9457SAndroid Build Coastguard Worker   }
3071*4bdc9457SAndroid Build Coastguard Worker }
3072*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_small_pool_with_input_stride)3073*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_small_pool_with_input_stride) {
3074*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3075*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3076*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
3077*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3078*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3079*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3080*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3081*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3082*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3083*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3084*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
3085*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3086*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3087*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3088*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3089*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3090*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3091*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3092*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3093*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
3094*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3095*4bdc9457SAndroid Build Coastguard Worker     }
3096*4bdc9457SAndroid Build Coastguard Worker   }
3097*4bdc9457SAndroid Build Coastguard Worker }
3098*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_small_pool_with_output_stride)3099*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_small_pool_with_output_stride) {
3100*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3101*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3102*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = 2; pool_size <= xnn_params.f32.maxpool.mr; pool_size++) {
3103*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3104*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3105*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3106*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3107*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3108*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3109*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3110*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
3111*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3112*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3113*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3114*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3115*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3116*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3117*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3118*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3119*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
3120*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3121*4bdc9457SAndroid Build Coastguard Worker     }
3122*4bdc9457SAndroid Build Coastguard Worker   }
3123*4bdc9457SAndroid Build Coastguard Worker }
3124*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_large_pool)3125*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_large_pool) {
3126*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3127*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3128*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
3129*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3130*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3131*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3132*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3133*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3134*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3135*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3136*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3137*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3138*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3139*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3140*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3141*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3142*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3143*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3144*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3145*4bdc9457SAndroid Build Coastguard Worker     }
3146*4bdc9457SAndroid Build Coastguard Worker   }
3147*4bdc9457SAndroid Build Coastguard Worker }
3148*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_large_pool_with_input_stride)3149*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_large_pool_with_input_stride) {
3150*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3151*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3152*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
3153*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3154*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3155*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3156*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3157*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3158*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3159*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3160*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
3161*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3162*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3163*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3164*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3165*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3166*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3167*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3168*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3169*4bdc9457SAndroid Build Coastguard Worker         .input_pixel_stride(5 * channels)
3170*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3171*4bdc9457SAndroid Build Coastguard Worker     }
3172*4bdc9457SAndroid Build Coastguard Worker   }
3173*4bdc9457SAndroid Build Coastguard Worker }
3174*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,small_batch_large_pool_with_output_stride)3175*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, small_batch_large_pool_with_output_stride) {
3176*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3177*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 100; channels += 15) {
3178*4bdc9457SAndroid Build Coastguard Worker     for (size_t pool_size = xnn_params.f32.maxpool.mr + 1; pool_size <= xnn_params.f32.maxpool.mr + xnn_params.f32.maxpool.qr; pool_size++) {
3179*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3180*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3181*4bdc9457SAndroid Build Coastguard Worker         .input_height(pool_size + 1)
3182*4bdc9457SAndroid Build Coastguard Worker         .input_width(3)
3183*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(pool_size)
3184*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(1)
3185*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3186*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
3187*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3188*4bdc9457SAndroid Build Coastguard Worker       MaxPoolingOperatorTester()
3189*4bdc9457SAndroid Build Coastguard Worker         .batch_size(3)
3190*4bdc9457SAndroid Build Coastguard Worker         .input_height(2)
3191*4bdc9457SAndroid Build Coastguard Worker         .input_width(pool_size + 2)
3192*4bdc9457SAndroid Build Coastguard Worker         .pooling_height(1)
3193*4bdc9457SAndroid Build Coastguard Worker         .pooling_width(pool_size)
3194*4bdc9457SAndroid Build Coastguard Worker         .channels(channels)
3195*4bdc9457SAndroid Build Coastguard Worker         .output_pixel_stride(5 * channels)
3196*4bdc9457SAndroid Build Coastguard Worker         .TestF32();
3197*4bdc9457SAndroid Build Coastguard Worker     }
3198*4bdc9457SAndroid Build Coastguard Worker   }
3199*4bdc9457SAndroid Build Coastguard Worker }
3200*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,setup_increasing_batch)3201*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, setup_increasing_batch) {
3202*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3203*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3204*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3205*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(5)
3206*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3207*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3208*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3209*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3210*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3211*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3212*4bdc9457SAndroid Build Coastguard Worker }
3213*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,setup_decreasing_batch)3214*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, setup_decreasing_batch) {
3215*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3216*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3217*4bdc9457SAndroid Build Coastguard Worker     .batch_size(5)
3218*4bdc9457SAndroid Build Coastguard Worker     .next_batch_size(3)
3219*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3220*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3221*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3222*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3223*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3224*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3225*4bdc9457SAndroid Build Coastguard Worker }
3226*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,setup_changing_height)3227*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, setup_changing_height) {
3228*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3229*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3230*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3231*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3232*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3233*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(9)
3234*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3235*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3236*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3237*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3238*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3239*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3240*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3241*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3242*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(7)
3243*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3244*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3245*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3246*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3247*4bdc9457SAndroid Build Coastguard Worker }
3248*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,setup_changing_width)3249*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, setup_changing_width) {
3250*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3251*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3252*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3253*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3254*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3255*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
3256*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3257*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3258*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3259*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3260*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3261*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3262*4bdc9457SAndroid Build Coastguard Worker     .input_height(8)
3263*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3264*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(7)
3265*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3266*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3267*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3268*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3269*4bdc9457SAndroid Build Coastguard Worker }
3270*4bdc9457SAndroid Build Coastguard Worker 
TEST(MAX_POOLING_NHWC_F32,setup_swap_height_and_width)3271*4bdc9457SAndroid Build Coastguard Worker TEST(MAX_POOLING_NHWC_F32, setup_swap_height_and_width) {
3272*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3273*4bdc9457SAndroid Build Coastguard Worker   MaxPoolingOperatorTester()
3274*4bdc9457SAndroid Build Coastguard Worker     .batch_size(3)
3275*4bdc9457SAndroid Build Coastguard Worker     .input_height(9)
3276*4bdc9457SAndroid Build Coastguard Worker     .input_width(8)
3277*4bdc9457SAndroid Build Coastguard Worker     .next_input_height(8)
3278*4bdc9457SAndroid Build Coastguard Worker     .next_input_width(9)
3279*4bdc9457SAndroid Build Coastguard Worker     .pooling_height(5)
3280*4bdc9457SAndroid Build Coastguard Worker     .pooling_width(3)
3281*4bdc9457SAndroid Build Coastguard Worker     .channels(24)
3282*4bdc9457SAndroid Build Coastguard Worker     .TestSetupF32();
3283*4bdc9457SAndroid Build Coastguard Worker }
3284