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 <utility>
12*4bdc9457SAndroid Build Coastguard Worker
13*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/params.h>
14*4bdc9457SAndroid Build Coastguard Worker
15*4bdc9457SAndroid Build Coastguard Worker #include "average-pooling-operator-tester.h"
16*4bdc9457SAndroid Build Coastguard Worker
SmallPoolSize(size_t max_elements)17*4bdc9457SAndroid Build Coastguard Worker static std::pair<size_t, size_t> SmallPoolSize(size_t max_elements) {
18*4bdc9457SAndroid Build Coastguard Worker const size_t small_side = size_t(std::floor(std::sqrt(double(max_elements))));
19*4bdc9457SAndroid Build Coastguard Worker const size_t large_side = small_side + 1;
20*4bdc9457SAndroid Build Coastguard Worker if (small_side * large_side < max_elements) {
21*4bdc9457SAndroid Build Coastguard Worker return std::make_pair(small_side, large_side);
22*4bdc9457SAndroid Build Coastguard Worker } else {
23*4bdc9457SAndroid Build Coastguard Worker return std::make_pair(small_side - 1, large_side - 1);
24*4bdc9457SAndroid Build Coastguard Worker }
25*4bdc9457SAndroid Build Coastguard Worker }
26*4bdc9457SAndroid Build Coastguard Worker
LargePoolSize(size_t min_elements)27*4bdc9457SAndroid Build Coastguard Worker static std::pair<size_t, size_t> LargePoolSize(size_t min_elements) {
28*4bdc9457SAndroid Build Coastguard Worker const size_t small_side = size_t(std::ceil(std::sqrt(double(min_elements))));
29*4bdc9457SAndroid Build Coastguard Worker return std::make_pair(small_side, small_side + 1);
30*4bdc9457SAndroid Build Coastguard Worker }
31*4bdc9457SAndroid Build Coastguard Worker
32*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass ****************************/
33*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool)34*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool) {
35*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
36*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
37*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
38*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
39*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
40*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
41*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
42*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
43*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
44*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
45*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
46*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
47*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
48*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
49*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
50*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
51*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
52*4bdc9457SAndroid Build Coastguard Worker }
53*4bdc9457SAndroid Build Coastguard Worker }
54*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_stride)55*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_stride) {
56*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
57*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
58*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
59*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
60*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
61*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
62*4bdc9457SAndroid Build Coastguard Worker continue;
63*4bdc9457SAndroid Build Coastguard Worker }
64*4bdc9457SAndroid Build Coastguard Worker
65*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
66*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
67*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
68*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
69*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
70*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
71*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
72*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
73*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
74*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
75*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
76*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
77*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
78*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
79*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
80*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
81*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
82*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
83*4bdc9457SAndroid Build Coastguard Worker }
84*4bdc9457SAndroid Build Coastguard Worker }
85*4bdc9457SAndroid Build Coastguard Worker }
86*4bdc9457SAndroid Build Coastguard Worker }
87*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_width_padding)88*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_width_padding) {
89*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
90*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
91*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
92*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
93*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
94*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
95*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
96*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
97*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
98*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
99*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
100*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
101*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
102*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
103*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
104*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
105*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
106*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
107*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
108*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
109*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
110*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
111*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
112*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
113*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
114*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
115*4bdc9457SAndroid Build Coastguard Worker }
116*4bdc9457SAndroid Build Coastguard Worker }
117*4bdc9457SAndroid Build Coastguard Worker }
118*4bdc9457SAndroid Build Coastguard Worker }
119*4bdc9457SAndroid Build Coastguard Worker }
120*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_height_padding)121*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_height_padding) {
122*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
123*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
124*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
125*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
126*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
127*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
128*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
129*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
130*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
131*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
132*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
133*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
134*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
135*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
136*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
137*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
138*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
139*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
140*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
141*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
142*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
143*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
144*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
145*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
146*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
147*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
148*4bdc9457SAndroid Build Coastguard Worker }
149*4bdc9457SAndroid Build Coastguard Worker }
150*4bdc9457SAndroid Build Coastguard Worker }
151*4bdc9457SAndroid Build Coastguard Worker }
152*4bdc9457SAndroid Build Coastguard Worker }
153*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_tf_same_padding)154*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_tf_same_padding) {
155*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
156*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
157*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
158*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
159*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
160*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
161*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
162*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
163*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
164*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
165*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
166*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
167*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
168*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
169*4bdc9457SAndroid Build Coastguard Worker }
170*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
171*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
172*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
173*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
174*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
175*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
176*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
177*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
178*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
179*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
180*4bdc9457SAndroid Build Coastguard Worker }
181*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
182*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
183*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
184*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
185*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
186*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
187*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
188*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
189*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
190*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
191*4bdc9457SAndroid Build Coastguard Worker }
192*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
193*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
194*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
195*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
196*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
197*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
198*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
199*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
200*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
201*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
202*4bdc9457SAndroid Build Coastguard Worker }
203*4bdc9457SAndroid Build Coastguard Worker }
204*4bdc9457SAndroid Build Coastguard Worker }
205*4bdc9457SAndroid Build Coastguard Worker }
206*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_input_stride)207*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_input_stride) {
208*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
209*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
210*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
211*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
212*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
213*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
214*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
215*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
216*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
217*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
218*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
219*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
220*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
221*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
222*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
223*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
224*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
225*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
226*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
227*4bdc9457SAndroid Build Coastguard Worker }
228*4bdc9457SAndroid Build Coastguard Worker }
229*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_output_stride)230*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_output_stride) {
231*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
232*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
233*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
234*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
235*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
236*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
237*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
238*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
239*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
240*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
241*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
242*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
243*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
244*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
245*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
246*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
247*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
248*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
249*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
250*4bdc9457SAndroid Build Coastguard Worker }
251*4bdc9457SAndroid Build Coastguard Worker }
252*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_input_scale)253*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_input_scale) {
254*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
255*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
256*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
257*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
258*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
259*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
260*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
261*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
262*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
263*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
264*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
265*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
266*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
267*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
268*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
269*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
270*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
271*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
272*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
273*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
274*4bdc9457SAndroid Build Coastguard Worker }
275*4bdc9457SAndroid Build Coastguard Worker }
276*4bdc9457SAndroid Build Coastguard Worker }
277*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_input_zero_point)278*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_input_zero_point) {
279*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
280*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
281*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
282*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
283*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
284*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
285*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
286*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
287*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
288*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
289*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
290*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
291*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
292*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
293*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
294*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
295*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
296*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
297*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
298*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
299*4bdc9457SAndroid Build Coastguard Worker }
300*4bdc9457SAndroid Build Coastguard Worker }
301*4bdc9457SAndroid Build Coastguard Worker }
302*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_output_scale)303*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_output_scale) {
304*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
305*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
306*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
307*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
308*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
309*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
310*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
311*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
312*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
313*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
314*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
315*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
316*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
317*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
318*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
319*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
320*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
321*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
322*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
323*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
324*4bdc9457SAndroid Build Coastguard Worker }
325*4bdc9457SAndroid Build Coastguard Worker }
326*4bdc9457SAndroid Build Coastguard Worker }
327*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_output_zero_point)328*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_output_zero_point) {
329*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
330*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
331*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
332*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
333*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
334*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
335*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
336*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
337*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
338*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
339*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
340*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
341*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
342*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
343*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
344*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
345*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
346*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
347*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
348*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
349*4bdc9457SAndroid Build Coastguard Worker }
350*4bdc9457SAndroid Build Coastguard Worker }
351*4bdc9457SAndroid Build Coastguard Worker }
352*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_qmin)353*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_qmin) {
354*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
355*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
356*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
357*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
358*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
359*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
360*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
361*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
362*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
363*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
364*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
365*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
366*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
367*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
368*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
369*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
370*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
371*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
372*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
373*4bdc9457SAndroid Build Coastguard Worker }
374*4bdc9457SAndroid Build Coastguard Worker }
375*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_pool_with_qmax)376*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_pool_with_qmax) {
377*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
378*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
379*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
380*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
381*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
382*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
383*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
384*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
385*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
386*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
387*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
388*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
389*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
390*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
391*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
392*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
393*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
394*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
395*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
396*4bdc9457SAndroid Build Coastguard Worker }
397*4bdc9457SAndroid Build Coastguard Worker }
398*4bdc9457SAndroid Build Coastguard Worker
399*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass, batched ****************************/
400*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool)401*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool) {
402*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
403*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
404*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
405*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
406*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
407*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
408*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
409*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
410*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
411*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
412*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
413*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
414*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
415*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
416*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
417*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
418*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
419*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
420*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
421*4bdc9457SAndroid Build Coastguard Worker }
422*4bdc9457SAndroid Build Coastguard Worker }
423*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_stride)424*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_stride) {
425*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
426*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
427*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
428*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
429*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
430*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
431*4bdc9457SAndroid Build Coastguard Worker continue;
432*4bdc9457SAndroid Build Coastguard Worker }
433*4bdc9457SAndroid Build Coastguard Worker
434*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
435*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
436*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
437*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
438*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
439*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
440*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
441*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
442*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
443*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
444*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
445*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
446*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
447*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
448*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
449*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
450*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
451*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
452*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
453*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
454*4bdc9457SAndroid Build Coastguard Worker }
455*4bdc9457SAndroid Build Coastguard Worker }
456*4bdc9457SAndroid Build Coastguard Worker }
457*4bdc9457SAndroid Build Coastguard Worker }
458*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_width_padding)459*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_width_padding) {
460*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
461*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
462*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
463*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
464*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
465*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
466*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
467*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
468*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
469*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
470*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
471*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
472*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
473*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
474*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
475*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
476*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
477*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
478*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
479*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
480*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
481*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
482*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
483*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
484*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
485*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
486*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
487*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
488*4bdc9457SAndroid Build Coastguard Worker }
489*4bdc9457SAndroid Build Coastguard Worker }
490*4bdc9457SAndroid Build Coastguard Worker }
491*4bdc9457SAndroid Build Coastguard Worker }
492*4bdc9457SAndroid Build Coastguard Worker }
493*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_height_padding)494*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_height_padding) {
495*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
496*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
497*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
498*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
499*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
500*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
501*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
502*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
503*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
504*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
505*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
506*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
507*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
508*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
509*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
510*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
511*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
512*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
513*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
514*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
515*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
516*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
517*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
518*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
519*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
520*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
521*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
522*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
523*4bdc9457SAndroid Build Coastguard Worker }
524*4bdc9457SAndroid Build Coastguard Worker }
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker }
527*4bdc9457SAndroid Build Coastguard Worker }
528*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_tf_same_padding)529*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_tf_same_padding) {
530*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
531*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
532*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
533*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
534*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
535*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
536*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
537*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
538*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
539*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
540*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
541*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
542*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
543*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
544*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
545*4bdc9457SAndroid Build Coastguard Worker }
546*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
547*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
548*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
549*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
550*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
551*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
552*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
553*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
554*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
555*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
556*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
557*4bdc9457SAndroid Build Coastguard Worker }
558*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
559*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
560*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
561*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
562*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
563*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
564*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
565*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
566*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
567*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
568*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
569*4bdc9457SAndroid Build Coastguard Worker }
570*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
571*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
572*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
573*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
574*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
575*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
576*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
577*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
578*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
579*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
580*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
581*4bdc9457SAndroid Build Coastguard Worker }
582*4bdc9457SAndroid Build Coastguard Worker }
583*4bdc9457SAndroid Build Coastguard Worker }
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_input_stride)586*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_input_stride) {
587*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
588*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
589*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
590*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
591*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
592*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
593*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
594*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
595*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
596*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
597*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
598*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
599*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
600*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
601*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
602*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
603*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
604*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
605*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
606*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
607*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
608*4bdc9457SAndroid Build Coastguard Worker }
609*4bdc9457SAndroid Build Coastguard Worker }
610*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_output_stride)611*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_output_stride) {
612*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
613*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
614*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
615*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
616*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
617*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
618*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
619*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
620*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
621*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
622*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
623*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
624*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
625*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
626*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
627*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
628*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
629*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
630*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
631*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
632*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
633*4bdc9457SAndroid Build Coastguard Worker }
634*4bdc9457SAndroid Build Coastguard Worker }
635*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_input_scale)636*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_input_scale) {
637*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
638*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
639*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
640*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
641*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
642*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
643*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
644*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
645*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
646*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
647*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
648*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
649*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
650*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
651*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
652*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
653*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
654*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
655*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
656*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
657*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
658*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
659*4bdc9457SAndroid Build Coastguard Worker }
660*4bdc9457SAndroid Build Coastguard Worker }
661*4bdc9457SAndroid Build Coastguard Worker }
662*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_input_zero_point)663*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_input_zero_point) {
664*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
665*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
666*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
667*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
668*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
669*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
670*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
671*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
672*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
673*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
674*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
675*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
676*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
677*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
678*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
679*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
680*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
681*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
682*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
683*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
684*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
685*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
686*4bdc9457SAndroid Build Coastguard Worker }
687*4bdc9457SAndroid Build Coastguard Worker }
688*4bdc9457SAndroid Build Coastguard Worker }
689*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_output_scale)690*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_output_scale) {
691*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
692*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
693*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
694*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
695*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
696*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
697*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
698*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
699*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
700*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
701*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
702*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
703*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
704*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
705*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
706*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
707*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
708*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
709*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
710*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
711*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
712*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
713*4bdc9457SAndroid Build Coastguard Worker }
714*4bdc9457SAndroid Build Coastguard Worker }
715*4bdc9457SAndroid Build Coastguard Worker }
716*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_output_zero_point)717*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_output_zero_point) {
718*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
719*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
720*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
721*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
722*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
723*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
724*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
725*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
726*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
727*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
728*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
729*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
730*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
731*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
732*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
733*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
734*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
735*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
736*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
737*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
738*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
739*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
740*4bdc9457SAndroid Build Coastguard Worker }
741*4bdc9457SAndroid Build Coastguard Worker }
742*4bdc9457SAndroid Build Coastguard Worker }
743*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_qmin)744*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_qmin) {
745*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
746*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
747*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
748*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
749*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
750*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
751*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
752*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
753*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
754*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
755*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
756*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
757*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
758*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
759*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
760*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
761*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
762*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
763*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
764*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
765*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
766*4bdc9457SAndroid Build Coastguard Worker }
767*4bdc9457SAndroid Build Coastguard Worker }
768*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_pool_with_qmax)769*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_pool_with_qmax) {
770*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
771*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.avgpool.primary_tile);
772*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
773*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
774*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
775*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
776*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
777*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
778*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
779*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
780*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
781*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
782*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
783*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
784*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
785*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
786*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
787*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
788*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
789*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
790*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
791*4bdc9457SAndroid Build Coastguard Worker }
792*4bdc9457SAndroid Build Coastguard Worker }
793*4bdc9457SAndroid Build Coastguard Worker
794*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass ****************************/
795*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool)796*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool) {
797*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
798*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.avgpool.primary_tile * 2);
799*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
800*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
801*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
802*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
803*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
804*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
805*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
806*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
807*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
808*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
809*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
810*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
811*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
812*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
813*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
814*4bdc9457SAndroid Build Coastguard Worker }
815*4bdc9457SAndroid Build Coastguard Worker }
816*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_stride)817*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_stride) {
818*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
819*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
820*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
821*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
822*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
823*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
824*4bdc9457SAndroid Build Coastguard Worker continue;
825*4bdc9457SAndroid Build Coastguard Worker }
826*4bdc9457SAndroid Build Coastguard Worker
827*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
828*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
829*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
830*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
831*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
832*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
833*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
834*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
835*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
836*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
837*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
838*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
839*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
840*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
841*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
842*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
843*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
844*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker }
847*4bdc9457SAndroid Build Coastguard Worker }
848*4bdc9457SAndroid Build Coastguard Worker }
849*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_width_padding)850*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_width_padding) {
851*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
852*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
853*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
854*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
855*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
856*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
857*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
858*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
859*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
860*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
861*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
862*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
863*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
864*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
865*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
866*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
867*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
868*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
869*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
870*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
871*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
872*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
873*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
874*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
875*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
876*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
877*4bdc9457SAndroid Build Coastguard Worker }
878*4bdc9457SAndroid Build Coastguard Worker }
879*4bdc9457SAndroid Build Coastguard Worker }
880*4bdc9457SAndroid Build Coastguard Worker }
881*4bdc9457SAndroid Build Coastguard Worker }
882*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_height_padding)883*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_height_padding) {
884*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
885*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
886*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
887*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
888*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
889*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
890*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
891*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
892*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
893*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
894*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
895*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
896*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
897*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
898*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
899*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
900*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
901*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
902*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
903*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
904*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
905*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
906*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
907*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
908*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
909*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
910*4bdc9457SAndroid Build Coastguard Worker }
911*4bdc9457SAndroid Build Coastguard Worker }
912*4bdc9457SAndroid Build Coastguard Worker }
913*4bdc9457SAndroid Build Coastguard Worker }
914*4bdc9457SAndroid Build Coastguard Worker }
915*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_tf_same_padding)916*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_tf_same_padding) {
917*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
918*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
919*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
920*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
921*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
922*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
923*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
924*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
925*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
926*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
927*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
928*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
929*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
930*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
931*4bdc9457SAndroid Build Coastguard Worker }
932*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
933*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
934*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
935*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
936*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
937*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
938*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
939*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
940*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
941*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
942*4bdc9457SAndroid Build Coastguard Worker }
943*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
944*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
945*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
946*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
947*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
948*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
949*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
950*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
951*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
952*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
953*4bdc9457SAndroid Build Coastguard Worker }
954*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
955*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
956*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
957*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
958*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
959*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
960*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
961*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
962*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
963*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
964*4bdc9457SAndroid Build Coastguard Worker }
965*4bdc9457SAndroid Build Coastguard Worker }
966*4bdc9457SAndroid Build Coastguard Worker }
967*4bdc9457SAndroid Build Coastguard Worker }
968*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_input_stride)969*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_input_stride) {
970*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
971*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
972*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
973*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
974*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
975*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
976*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
977*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
978*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
979*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
980*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
981*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
982*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
983*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
984*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
985*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
986*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
987*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
988*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
989*4bdc9457SAndroid Build Coastguard Worker }
990*4bdc9457SAndroid Build Coastguard Worker }
991*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_output_stride)992*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_output_stride) {
993*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
994*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
995*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
996*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
997*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
998*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
999*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1000*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1001*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1002*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1003*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1004*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1005*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1006*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1007*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1008*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1009*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1010*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1011*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1012*4bdc9457SAndroid Build Coastguard Worker }
1013*4bdc9457SAndroid Build Coastguard Worker }
1014*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_input_scale)1015*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_input_scale) {
1016*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1017*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1018*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1019*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
1020*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1021*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1022*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1023*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1024*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1025*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1026*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1027*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1028*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1029*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1030*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1031*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1032*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1033*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1034*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1035*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1036*4bdc9457SAndroid Build Coastguard Worker }
1037*4bdc9457SAndroid Build Coastguard Worker }
1038*4bdc9457SAndroid Build Coastguard Worker }
1039*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_input_zero_point)1040*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_input_zero_point) {
1041*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1042*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1043*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1044*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
1045*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1046*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1047*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1048*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1049*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1050*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1051*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1052*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1053*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1054*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1055*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1056*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1057*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1058*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1059*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1060*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1061*4bdc9457SAndroid Build Coastguard Worker }
1062*4bdc9457SAndroid Build Coastguard Worker }
1063*4bdc9457SAndroid Build Coastguard Worker }
1064*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_output_scale)1065*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_output_scale) {
1066*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1067*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1068*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1069*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
1070*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1071*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1072*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1073*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1074*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1075*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1076*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1077*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1078*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1079*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1080*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1081*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1082*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1083*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1084*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1085*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1086*4bdc9457SAndroid Build Coastguard Worker }
1087*4bdc9457SAndroid Build Coastguard Worker }
1088*4bdc9457SAndroid Build Coastguard Worker }
1089*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_output_zero_point)1090*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_output_zero_point) {
1091*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1092*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1093*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1094*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
1095*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1096*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1097*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1098*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1099*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1100*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1101*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1102*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1103*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1104*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1105*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1106*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1107*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1108*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1109*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1110*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1111*4bdc9457SAndroid Build Coastguard Worker }
1112*4bdc9457SAndroid Build Coastguard Worker }
1113*4bdc9457SAndroid Build Coastguard Worker }
1114*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_qmin)1115*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_qmin) {
1116*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1117*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1118*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1119*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1120*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1121*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1122*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1123*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1124*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1125*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1126*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1127*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1128*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1129*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1130*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1131*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1132*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1133*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1134*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1135*4bdc9457SAndroid Build Coastguard Worker }
1136*4bdc9457SAndroid Build Coastguard Worker }
1137*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_pool_with_qmax)1138*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_pool_with_qmax) {
1139*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1140*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1141*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1142*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1143*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1144*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1145*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1146*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1147*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1148*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1149*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1150*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1151*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1152*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1153*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1154*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1155*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1156*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1157*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1158*4bdc9457SAndroid Build Coastguard Worker }
1159*4bdc9457SAndroid Build Coastguard Worker }
1160*4bdc9457SAndroid Build Coastguard Worker
1161*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass, batched ****************************/
1162*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool)1163*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool) {
1164*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1165*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.avgpool.primary_tile * 2);
1166*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1167*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1168*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1169*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1170*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1171*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1172*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1173*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1174*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1175*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1176*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1177*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1178*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1179*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1180*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1181*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1182*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1183*4bdc9457SAndroid Build Coastguard Worker }
1184*4bdc9457SAndroid Build Coastguard Worker }
1185*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_stride)1186*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_stride) {
1187*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1188*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1189*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1190*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
1191*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
1192*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
1193*4bdc9457SAndroid Build Coastguard Worker continue;
1194*4bdc9457SAndroid Build Coastguard Worker }
1195*4bdc9457SAndroid Build Coastguard Worker
1196*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1197*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1198*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1199*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1200*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1201*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1202*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
1203*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
1204*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1205*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1206*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1207*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1208*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1209*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1210*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1211*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1212*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
1213*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
1214*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1215*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1216*4bdc9457SAndroid Build Coastguard Worker }
1217*4bdc9457SAndroid Build Coastguard Worker }
1218*4bdc9457SAndroid Build Coastguard Worker }
1219*4bdc9457SAndroid Build Coastguard Worker }
1220*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_width_padding)1221*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_width_padding) {
1222*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1223*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1224*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1225*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
1226*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
1227*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
1228*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1229*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1230*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1231*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1232*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
1233*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
1234*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1235*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1236*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1237*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1238*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1239*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1240*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1241*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1242*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1243*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
1244*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
1245*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1246*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1247*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1248*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1249*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1250*4bdc9457SAndroid Build Coastguard Worker }
1251*4bdc9457SAndroid Build Coastguard Worker }
1252*4bdc9457SAndroid Build Coastguard Worker }
1253*4bdc9457SAndroid Build Coastguard Worker }
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_height_padding)1256*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_height_padding) {
1257*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1258*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1259*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1260*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
1261*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
1262*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
1263*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1264*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1265*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1266*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1267*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
1268*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
1269*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1270*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1271*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1272*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1273*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1274*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1275*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1276*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1277*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1278*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
1279*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
1280*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1281*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1282*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1283*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1284*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1285*4bdc9457SAndroid Build Coastguard Worker }
1286*4bdc9457SAndroid Build Coastguard Worker }
1287*4bdc9457SAndroid Build Coastguard Worker }
1288*4bdc9457SAndroid Build Coastguard Worker }
1289*4bdc9457SAndroid Build Coastguard Worker }
1290*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_tf_same_padding)1291*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_tf_same_padding) {
1292*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1293*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1294*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1295*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
1296*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
1297*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1298*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1299*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
1300*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1301*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1302*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1303*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1304*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1305*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1306*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1307*4bdc9457SAndroid Build Coastguard Worker }
1308*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
1309*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1310*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1311*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1312*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
1313*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1314*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1315*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1316*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1317*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1318*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1319*4bdc9457SAndroid Build Coastguard Worker }
1320*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
1321*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1322*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1323*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
1324*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1325*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1326*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1327*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1328*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1329*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1330*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1331*4bdc9457SAndroid Build Coastguard Worker }
1332*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
1333*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1334*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1335*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1336*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
1337*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1338*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1339*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1340*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
1341*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1342*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1343*4bdc9457SAndroid Build Coastguard Worker }
1344*4bdc9457SAndroid Build Coastguard Worker }
1345*4bdc9457SAndroid Build Coastguard Worker }
1346*4bdc9457SAndroid Build Coastguard Worker }
1347*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_input_stride)1348*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_input_stride) {
1349*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1350*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1351*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1352*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1353*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1354*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1355*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1356*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1357*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1358*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1359*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1360*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1361*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1362*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1363*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1364*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1365*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1366*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1367*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1368*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1369*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1370*4bdc9457SAndroid Build Coastguard Worker }
1371*4bdc9457SAndroid Build Coastguard Worker }
1372*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_output_stride)1373*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_output_stride) {
1374*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1375*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1376*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1377*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1378*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1379*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1380*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1381*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1382*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1383*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1384*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1385*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1386*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1387*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1388*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1389*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1390*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1391*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1392*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1393*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1394*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1395*4bdc9457SAndroid Build Coastguard Worker }
1396*4bdc9457SAndroid Build Coastguard Worker }
1397*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_input_scale)1398*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_input_scale) {
1399*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1400*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1401*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1402*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
1403*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1404*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1405*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1406*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1407*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1408*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1409*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1410*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1411*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1412*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1413*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1414*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1415*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1416*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1417*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1418*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1419*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1420*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1421*4bdc9457SAndroid Build Coastguard Worker }
1422*4bdc9457SAndroid Build Coastguard Worker }
1423*4bdc9457SAndroid Build Coastguard Worker }
1424*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_input_zero_point)1425*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_input_zero_point) {
1426*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1427*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1428*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1429*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
1430*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1431*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1432*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1433*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1434*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1435*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1436*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1437*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1438*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1439*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1440*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1441*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1442*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1443*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1444*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1445*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1446*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1447*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1448*4bdc9457SAndroid Build Coastguard Worker }
1449*4bdc9457SAndroid Build Coastguard Worker }
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_output_scale)1452*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_output_scale) {
1453*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1454*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1455*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1456*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
1457*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1458*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1459*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1460*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1461*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1462*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1463*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1464*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1465*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1466*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1467*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1468*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1469*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1470*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1471*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1472*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1473*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1474*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1475*4bdc9457SAndroid Build Coastguard Worker }
1476*4bdc9457SAndroid Build Coastguard Worker }
1477*4bdc9457SAndroid Build Coastguard Worker }
1478*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_output_zero_point)1479*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_output_zero_point) {
1480*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1481*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1482*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1483*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
1484*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1485*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1486*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1487*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1488*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1489*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1490*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1491*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1492*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1493*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1494*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1495*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1496*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1497*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1498*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1499*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1500*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1501*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1502*4bdc9457SAndroid Build Coastguard Worker }
1503*4bdc9457SAndroid Build Coastguard Worker }
1504*4bdc9457SAndroid Build Coastguard Worker }
1505*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_qmin)1506*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_qmin) {
1507*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1508*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1509*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1510*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1511*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1512*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1513*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1514*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1515*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1516*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1517*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1518*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1519*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1520*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1521*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1522*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1523*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1524*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1525*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1526*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1527*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1528*4bdc9457SAndroid Build Coastguard Worker }
1529*4bdc9457SAndroid Build Coastguard Worker }
1530*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_pool_with_qmax)1531*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_pool_with_qmax) {
1532*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1533*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
1534*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1535*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1536*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1537*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
1538*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
1539*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1540*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1541*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1542*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1543*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1544*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1545*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1546*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
1547*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
1548*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1549*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1550*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1551*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1552*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1553*4bdc9457SAndroid Build Coastguard Worker }
1554*4bdc9457SAndroid Build Coastguard Worker }
1555*4bdc9457SAndroid Build Coastguard Worker
1556*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass ****************************/
1557*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image)1558*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image) {
1559*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1560*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1561*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1562*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1563*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1564*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1565*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1566*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1567*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1568*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1569*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1570*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1571*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1572*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1573*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1574*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1575*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1576*4bdc9457SAndroid Build Coastguard Worker }
1577*4bdc9457SAndroid Build Coastguard Worker }
1578*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_width_padding)1579*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_width_padding) {
1580*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1581*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
1582*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1583*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
1584*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1585*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1586*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
1587*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1588*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1589*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1590*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1591*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1592*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1593*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1594*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
1595*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1596*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1597*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1598*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1599*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1600*4bdc9457SAndroid Build Coastguard Worker
1601*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
1602*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1603*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1604*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
1605*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1606*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1607*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1608*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1609*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1610*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1611*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1612*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
1613*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1614*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1615*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1616*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1617*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1618*4bdc9457SAndroid Build Coastguard Worker }
1619*4bdc9457SAndroid Build Coastguard Worker }
1620*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_height_padding)1621*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_height_padding) {
1622*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1623*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1624*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1625*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
1626*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1627*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
1628*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1629*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1630*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1631*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1632*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1633*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1634*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1635*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
1636*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1637*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1638*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1639*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1640*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1641*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1642*4bdc9457SAndroid Build Coastguard Worker
1643*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
1644*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1645*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
1646*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1647*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1648*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1649*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1650*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1651*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1652*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1653*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
1654*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1655*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1656*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1657*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1658*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1659*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1660*4bdc9457SAndroid Build Coastguard Worker }
1661*4bdc9457SAndroid Build Coastguard Worker }
1662*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_input_stride)1663*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_input_stride) {
1664*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1665*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1666*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1667*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1668*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1669*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1670*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1671*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1672*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1673*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1674*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1675*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1676*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1677*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1678*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1679*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1680*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1681*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1682*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1683*4bdc9457SAndroid Build Coastguard Worker }
1684*4bdc9457SAndroid Build Coastguard Worker }
1685*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_output_stride)1686*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_output_stride) {
1687*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1688*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1689*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1690*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1691*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1692*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1693*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1694*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1695*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1696*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1697*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1698*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1699*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1700*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1701*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1702*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1703*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1704*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
1705*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1706*4bdc9457SAndroid Build Coastguard Worker }
1707*4bdc9457SAndroid Build Coastguard Worker }
1708*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_input_scale)1709*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_input_scale) {
1710*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1711*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1712*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1713*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
1714*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1715*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1716*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1717*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1718*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1719*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1720*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1721*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1722*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1723*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1724*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1725*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1726*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1727*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1728*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
1729*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1730*4bdc9457SAndroid Build Coastguard Worker }
1731*4bdc9457SAndroid Build Coastguard Worker }
1732*4bdc9457SAndroid Build Coastguard Worker }
1733*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_input_zero_point)1734*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_input_zero_point) {
1735*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1736*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1737*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1738*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
1739*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1740*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1741*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1742*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1743*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1744*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1745*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1746*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1747*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1748*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1749*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1750*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1751*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1752*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1753*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
1754*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1755*4bdc9457SAndroid Build Coastguard Worker }
1756*4bdc9457SAndroid Build Coastguard Worker }
1757*4bdc9457SAndroid Build Coastguard Worker }
1758*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_output_scale)1759*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_output_scale) {
1760*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1761*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1762*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1763*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
1764*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1765*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1766*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1767*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1768*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1769*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1770*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1771*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1772*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1773*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1774*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1775*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1776*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1777*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1778*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
1779*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1780*4bdc9457SAndroid Build Coastguard Worker }
1781*4bdc9457SAndroid Build Coastguard Worker }
1782*4bdc9457SAndroid Build Coastguard Worker }
1783*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_output_zero_point)1784*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_output_zero_point) {
1785*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1786*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1787*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1788*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
1789*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1790*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1791*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1792*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1793*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1794*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1795*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1796*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1797*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1798*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1799*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1800*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1801*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1802*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1803*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
1804*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1805*4bdc9457SAndroid Build Coastguard Worker }
1806*4bdc9457SAndroid Build Coastguard Worker }
1807*4bdc9457SAndroid Build Coastguard Worker }
1808*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_qmin)1809*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_qmin) {
1810*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1811*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1812*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1813*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1814*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1815*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1816*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1817*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1818*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1819*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1820*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1821*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1822*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1823*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1824*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1825*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1826*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1827*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1828*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1829*4bdc9457SAndroid Build Coastguard Worker }
1830*4bdc9457SAndroid Build Coastguard Worker }
1831*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,small_image_with_qmax)1832*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, small_image_with_qmax) {
1833*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1834*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1835*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1836*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1837*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1838*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1839*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1840*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1841*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1842*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1843*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1844*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1845*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1846*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1847*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1848*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1849*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1850*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1851*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1852*4bdc9457SAndroid Build Coastguard Worker }
1853*4bdc9457SAndroid Build Coastguard Worker }
1854*4bdc9457SAndroid Build Coastguard Worker
1855*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass, batched ****************************/
1856*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image)1857*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image) {
1858*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1859*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1860*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1861*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1862*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1863*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1864*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1865*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1866*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1867*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1868*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1869*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1870*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1871*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1872*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1873*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1874*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1875*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1876*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1877*4bdc9457SAndroid Build Coastguard Worker }
1878*4bdc9457SAndroid Build Coastguard Worker }
1879*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_width_padding)1880*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_width_padding) {
1881*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1882*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
1883*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1884*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
1885*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1886*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1887*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1888*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
1889*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1890*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1891*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1892*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1893*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1894*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1895*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1896*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1897*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
1898*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1899*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1900*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1901*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1902*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1903*4bdc9457SAndroid Build Coastguard Worker
1904*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
1905*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1906*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1907*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1908*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
1909*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1910*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1911*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1912*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1913*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1914*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1915*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1916*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1917*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
1918*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1919*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1920*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1921*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1922*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1923*4bdc9457SAndroid Build Coastguard Worker }
1924*4bdc9457SAndroid Build Coastguard Worker }
1925*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_height_padding)1926*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_height_padding) {
1927*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1928*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1929*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1930*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
1931*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1932*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1933*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
1934*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1935*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1936*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1937*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1938*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1939*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1940*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1941*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1942*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
1943*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1944*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1945*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1946*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1947*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1948*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1949*4bdc9457SAndroid Build Coastguard Worker
1950*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
1951*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1952*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1953*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
1954*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1955*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1956*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1957*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1958*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1959*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1960*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1961*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1962*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
1963*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1964*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1965*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1966*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1967*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1968*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1969*4bdc9457SAndroid Build Coastguard Worker }
1970*4bdc9457SAndroid Build Coastguard Worker }
1971*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_input_stride)1972*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_input_stride) {
1973*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1974*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
1975*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
1976*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1977*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1978*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
1979*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
1980*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
1981*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
1982*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1983*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1984*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1985*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
1986*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
1987*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
1988*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
1989*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
1990*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
1991*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
1992*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
1993*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
1994*4bdc9457SAndroid Build Coastguard Worker }
1995*4bdc9457SAndroid Build Coastguard Worker }
1996*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_output_stride)1997*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_output_stride) {
1998*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1999*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2000*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2001*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2002*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2003*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2004*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2005*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2006*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2007*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2008*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2009*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2010*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2011*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2012*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2013*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2014*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2015*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2016*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2017*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2018*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2019*4bdc9457SAndroid Build Coastguard Worker }
2020*4bdc9457SAndroid Build Coastguard Worker }
2021*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_input_scale)2022*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_input_scale) {
2023*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2024*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2025*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2026*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
2027*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2028*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2029*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2030*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2031*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2032*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2033*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2034*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2035*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2036*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2037*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2038*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2039*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2040*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2041*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2042*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2043*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2044*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2045*4bdc9457SAndroid Build Coastguard Worker }
2046*4bdc9457SAndroid Build Coastguard Worker }
2047*4bdc9457SAndroid Build Coastguard Worker }
2048*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_input_zero_point)2049*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_input_zero_point) {
2050*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2051*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2052*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2053*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
2054*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2055*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2056*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2057*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2058*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2059*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2060*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2061*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2062*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2063*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2064*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2065*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2066*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2067*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2068*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2069*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2070*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2071*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2072*4bdc9457SAndroid Build Coastguard Worker }
2073*4bdc9457SAndroid Build Coastguard Worker }
2074*4bdc9457SAndroid Build Coastguard Worker }
2075*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_output_scale)2076*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_output_scale) {
2077*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2078*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2079*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2080*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
2081*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2082*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2083*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2084*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2085*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2086*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2087*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2088*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2089*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2090*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2091*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2092*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2093*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2094*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2095*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2096*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2097*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2098*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2099*4bdc9457SAndroid Build Coastguard Worker }
2100*4bdc9457SAndroid Build Coastguard Worker }
2101*4bdc9457SAndroid Build Coastguard Worker }
2102*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_output_zero_point)2103*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_output_zero_point) {
2104*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2105*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2106*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2107*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
2108*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2109*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2110*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2111*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2112*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2113*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2114*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2115*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2116*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2117*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2118*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2119*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2120*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2121*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2122*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2123*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2124*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2125*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2126*4bdc9457SAndroid Build Coastguard Worker }
2127*4bdc9457SAndroid Build Coastguard Worker }
2128*4bdc9457SAndroid Build Coastguard Worker }
2129*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_qmin)2130*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_qmin) {
2131*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2132*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2133*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2134*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2135*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2136*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2137*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2138*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2139*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2140*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2141*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2142*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2143*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2144*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2145*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2146*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2147*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2148*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2149*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2150*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2151*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2152*4bdc9457SAndroid Build Coastguard Worker }
2153*4bdc9457SAndroid Build Coastguard Worker }
2154*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_small_image_with_qmax)2155*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_small_image_with_qmax) {
2156*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2157*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.qu8.gavgpool.row_tile);
2158*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2159*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2160*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2161*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2162*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2163*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2164*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2165*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2166*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2167*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2168*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2169*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2170*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2171*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2172*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2173*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2174*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2175*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2176*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2177*4bdc9457SAndroid Build Coastguard Worker }
2178*4bdc9457SAndroid Build Coastguard Worker }
2179*4bdc9457SAndroid Build Coastguard Worker
2180*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass ****************************/
2181*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image)2182*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image) {
2183*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2184*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2185*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2186*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2187*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2188*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2189*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2190*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2191*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2192*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2193*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2194*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2195*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2196*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2197*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2198*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2199*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2200*4bdc9457SAndroid Build Coastguard Worker }
2201*4bdc9457SAndroid Build Coastguard Worker }
2202*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_width_padding)2203*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_width_padding) {
2204*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2205*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2206*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2207*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
2208*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2209*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2210*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
2211*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2212*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2213*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2214*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2215*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2216*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2217*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2218*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
2219*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2220*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2221*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2222*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2223*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2224*4bdc9457SAndroid Build Coastguard Worker }
2225*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
2226*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2227*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2228*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
2229*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
2230*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2231*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2232*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2233*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2234*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2235*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2236*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
2237*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
2238*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2239*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2240*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2241*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2242*4bdc9457SAndroid Build Coastguard Worker }
2243*4bdc9457SAndroid Build Coastguard Worker }
2244*4bdc9457SAndroid Build Coastguard Worker }
2245*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_height_padding)2246*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_height_padding) {
2247*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2248*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2249*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2250*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 1; padding_top <= 2; padding_top++) {
2251*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2252*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
2253*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2254*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
2255*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2256*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2257*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2258*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2259*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2260*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
2261*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2262*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
2263*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2264*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2265*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2266*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2267*4bdc9457SAndroid Build Coastguard Worker }
2268*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
2269*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2270*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
2271*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2272*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
2273*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2274*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2275*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2276*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2277*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2278*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
2279*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2280*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
2281*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2282*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2283*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2284*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2285*4bdc9457SAndroid Build Coastguard Worker }
2286*4bdc9457SAndroid Build Coastguard Worker }
2287*4bdc9457SAndroid Build Coastguard Worker }
2288*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_input_stride)2289*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_input_stride) {
2290*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2291*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2292*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2293*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2294*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2295*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2296*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2297*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2298*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2299*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
2300*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2301*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2302*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2303*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2304*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2305*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2306*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2307*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
2308*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2309*4bdc9457SAndroid Build Coastguard Worker }
2310*4bdc9457SAndroid Build Coastguard Worker }
2311*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_output_stride)2312*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_output_stride) {
2313*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2314*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2315*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2316*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2317*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2318*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2319*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2320*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2321*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2322*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2323*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2324*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2325*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2326*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2327*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2328*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2329*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2330*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2331*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2332*4bdc9457SAndroid Build Coastguard Worker }
2333*4bdc9457SAndroid Build Coastguard Worker }
2334*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_input_scale)2335*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_input_scale) {
2336*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2337*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2338*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2339*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
2340*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2341*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2342*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2343*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2344*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2345*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2346*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2347*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2348*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2349*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2350*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2351*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2352*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2353*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2354*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2355*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2356*4bdc9457SAndroid Build Coastguard Worker }
2357*4bdc9457SAndroid Build Coastguard Worker }
2358*4bdc9457SAndroid Build Coastguard Worker }
2359*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_input_zero_point)2360*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_input_zero_point) {
2361*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2362*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2363*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2364*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
2365*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2366*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2367*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2368*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2369*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2370*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2371*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2372*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2373*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2374*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2375*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2376*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2377*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2378*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2379*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2380*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2381*4bdc9457SAndroid Build Coastguard Worker }
2382*4bdc9457SAndroid Build Coastguard Worker }
2383*4bdc9457SAndroid Build Coastguard Worker }
2384*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_output_scale)2385*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_output_scale) {
2386*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2387*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2388*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2389*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
2390*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2391*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2392*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2393*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2394*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2395*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2396*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2397*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2398*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2399*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2400*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2401*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2402*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2403*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2404*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2405*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2406*4bdc9457SAndroid Build Coastguard Worker }
2407*4bdc9457SAndroid Build Coastguard Worker }
2408*4bdc9457SAndroid Build Coastguard Worker }
2409*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_output_zero_point)2410*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_output_zero_point) {
2411*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2412*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2413*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2414*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
2415*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2416*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2417*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2418*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2419*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2420*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2421*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2422*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2423*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2424*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2425*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2426*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2427*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2428*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2429*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2430*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2431*4bdc9457SAndroid Build Coastguard Worker }
2432*4bdc9457SAndroid Build Coastguard Worker }
2433*4bdc9457SAndroid Build Coastguard Worker }
2434*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_qmin)2435*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_qmin) {
2436*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2437*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2438*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2439*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2440*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2441*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2442*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2443*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2444*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2445*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2446*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2447*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2448*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2449*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2450*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2451*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2452*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2453*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2454*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2455*4bdc9457SAndroid Build Coastguard Worker }
2456*4bdc9457SAndroid Build Coastguard Worker }
2457*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,large_image_with_qmax)2458*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, large_image_with_qmax) {
2459*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2460*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2461*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2462*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2463*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2464*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2465*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2466*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2467*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2468*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2469*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2470*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2471*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2472*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2473*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2474*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2475*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2476*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2477*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2478*4bdc9457SAndroid Build Coastguard Worker }
2479*4bdc9457SAndroid Build Coastguard Worker }
2480*4bdc9457SAndroid Build Coastguard Worker
2481*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass, batched ****************************/
2482*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image)2483*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image) {
2484*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2485*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2486*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2487*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2488*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2489*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2490*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2491*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2492*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2493*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2494*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2495*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2496*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2497*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2498*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2499*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2500*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2501*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2502*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2503*4bdc9457SAndroid Build Coastguard Worker }
2504*4bdc9457SAndroid Build Coastguard Worker }
2505*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_width_padding)2506*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_width_padding) {
2507*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2508*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2509*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2510*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
2511*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2512*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2513*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2514*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
2515*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2516*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2517*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2518*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2519*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2520*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2521*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2522*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2523*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
2524*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2525*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2526*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2527*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2528*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2529*4bdc9457SAndroid Build Coastguard Worker }
2530*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
2531*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2532*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2533*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2534*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
2535*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
2536*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2537*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2538*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2539*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2540*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2541*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2542*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2543*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
2544*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
2545*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2546*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2547*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2548*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2549*4bdc9457SAndroid Build Coastguard Worker }
2550*4bdc9457SAndroid Build Coastguard Worker }
2551*4bdc9457SAndroid Build Coastguard Worker }
2552*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_height_padding)2553*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_height_padding) {
2554*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2555*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2556*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2557*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 1; padding_top <= 2; padding_top++) {
2558*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2559*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2560*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
2561*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2562*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
2563*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2564*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2565*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2566*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2567*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2568*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2569*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
2570*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2571*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
2572*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2573*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2574*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2575*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2576*4bdc9457SAndroid Build Coastguard Worker }
2577*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 1; padding_bottom <= 2; padding_bottom++) {
2578*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2579*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2580*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
2581*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2582*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
2583*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2584*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2585*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2586*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2587*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2588*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2589*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
2590*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2591*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
2592*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2593*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2594*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2595*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2596*4bdc9457SAndroid Build Coastguard Worker }
2597*4bdc9457SAndroid Build Coastguard Worker }
2598*4bdc9457SAndroid Build Coastguard Worker }
2599*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_input_stride)2600*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_input_stride) {
2601*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2602*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2603*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2604*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2605*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2606*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2607*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2608*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2609*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2610*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2611*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
2612*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2613*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2614*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2615*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2616*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2617*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2618*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2619*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2620*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
2621*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2622*4bdc9457SAndroid Build Coastguard Worker }
2623*4bdc9457SAndroid Build Coastguard Worker }
2624*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_output_stride)2625*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_output_stride) {
2626*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2627*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2628*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2629*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2630*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2631*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2632*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2633*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2634*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2635*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2636*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2637*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2638*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2639*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2640*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2641*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2642*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2643*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2644*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2645*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
2646*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2647*4bdc9457SAndroid Build Coastguard Worker }
2648*4bdc9457SAndroid Build Coastguard Worker }
2649*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_input_scale)2650*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_input_scale) {
2651*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2652*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2653*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2654*4bdc9457SAndroid Build Coastguard Worker for (float input_scale = 0.01f; input_scale < 100.0f; input_scale *= 3.14159265f) {
2655*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2656*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2657*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2658*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2659*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2660*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2661*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2662*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2663*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2664*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2665*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2666*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2667*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2668*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2669*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2670*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2671*4bdc9457SAndroid Build Coastguard Worker .input_scale(input_scale)
2672*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2673*4bdc9457SAndroid Build Coastguard Worker }
2674*4bdc9457SAndroid Build Coastguard Worker }
2675*4bdc9457SAndroid Build Coastguard Worker }
2676*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_input_zero_point)2677*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_input_zero_point) {
2678*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2679*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2680*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2681*4bdc9457SAndroid Build Coastguard Worker for (int32_t input_zero_point = 0; input_zero_point <= 255; input_zero_point += 51) {
2682*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2683*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2684*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2685*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2686*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2687*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2688*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2689*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2690*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2691*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2692*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2693*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2694*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2695*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2696*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2697*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2698*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(uint8_t(input_zero_point))
2699*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2700*4bdc9457SAndroid Build Coastguard Worker }
2701*4bdc9457SAndroid Build Coastguard Worker }
2702*4bdc9457SAndroid Build Coastguard Worker }
2703*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_output_scale)2704*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_output_scale) {
2705*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2706*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2707*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2708*4bdc9457SAndroid Build Coastguard Worker for (float output_scale = 0.01f; output_scale < 100.0f; output_scale *= 3.14159265f) {
2709*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2710*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2711*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2712*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2713*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2714*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2715*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2716*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2717*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2718*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2719*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2720*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2721*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2722*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2723*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2724*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2725*4bdc9457SAndroid Build Coastguard Worker .output_scale(output_scale)
2726*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2727*4bdc9457SAndroid Build Coastguard Worker }
2728*4bdc9457SAndroid Build Coastguard Worker }
2729*4bdc9457SAndroid Build Coastguard Worker }
2730*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_output_zero_point)2731*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_output_zero_point) {
2732*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2733*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2734*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2735*4bdc9457SAndroid Build Coastguard Worker for (int32_t output_zero_point = 0; output_zero_point <= 255; output_zero_point += 51) {
2736*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2737*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2738*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2739*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2740*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2741*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2742*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2743*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2744*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2745*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2746*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2747*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2748*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2749*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2750*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2751*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2752*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(uint8_t(output_zero_point))
2753*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2754*4bdc9457SAndroid Build Coastguard Worker }
2755*4bdc9457SAndroid Build Coastguard Worker }
2756*4bdc9457SAndroid Build Coastguard Worker }
2757*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_qmin)2758*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_qmin) {
2759*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2760*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2761*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2762*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2763*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2764*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2765*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2766*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2767*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2768*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2769*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2770*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2771*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2772*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2773*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2774*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2775*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2776*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2777*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2778*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2779*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2780*4bdc9457SAndroid Build Coastguard Worker }
2781*4bdc9457SAndroid Build Coastguard Worker }
2782*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,batched_large_image_with_qmax)2783*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, batched_large_image_with_qmax) {
2784*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2785*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.qu8.gavgpool.row_tile * 2);
2786*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2787*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2788*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2789*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
2790*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
2791*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2792*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2793*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2794*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2795*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2796*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2797*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2798*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
2799*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
2800*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2801*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2802*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2803*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2804*4bdc9457SAndroid Build Coastguard Worker .TestQU8();
2805*4bdc9457SAndroid Build Coastguard Worker }
2806*4bdc9457SAndroid Build Coastguard Worker }
2807*4bdc9457SAndroid Build Coastguard Worker
2808*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, setup ****************************/
2809*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_increasing_batch)2810*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_increasing_batch) {
2811*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2812*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2813*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2814*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
2815*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2816*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2817*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2818*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2819*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2820*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2821*4bdc9457SAndroid Build Coastguard Worker }
2822*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_decreasing_batch)2823*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_decreasing_batch) {
2824*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2825*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2826*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
2827*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(2)
2828*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2829*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2830*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2831*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2832*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2833*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2834*4bdc9457SAndroid Build Coastguard Worker }
2835*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_changing_height)2836*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_changing_height) {
2837*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2838*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2839*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2840*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2841*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2842*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
2843*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2844*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2845*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2846*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2847*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2848*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2849*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2850*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2851*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
2852*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2853*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2854*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2855*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2856*4bdc9457SAndroid Build Coastguard Worker }
2857*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_changing_width)2858*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_changing_width) {
2859*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2860*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2861*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2862*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2863*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2864*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2865*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2866*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2867*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2868*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2869*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2870*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2871*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2872*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2873*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
2874*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2875*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2876*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2877*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2878*4bdc9457SAndroid Build Coastguard Worker }
2879*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_swap_height_and_width)2880*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_swap_height_and_width) {
2881*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2882*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2883*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2884*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
2885*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2886*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
2887*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2888*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2889*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2890*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2891*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2892*4bdc9457SAndroid Build Coastguard Worker }
2893*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_local_to_global)2894*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_local_to_global) {
2895*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2896*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2897*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2898*4bdc9457SAndroid Build Coastguard Worker .input_height(6)
2899*4bdc9457SAndroid Build Coastguard Worker .input_width(5)
2900*4bdc9457SAndroid Build Coastguard Worker .next_input_height(5)
2901*4bdc9457SAndroid Build Coastguard Worker .next_input_width(3)
2902*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2903*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2904*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2905*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2906*4bdc9457SAndroid Build Coastguard Worker }
2907*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_QU8,setup_global_to_local)2908*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_QU8, setup_global_to_local) {
2909*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2910*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2911*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2912*4bdc9457SAndroid Build Coastguard Worker .input_height(5)
2913*4bdc9457SAndroid Build Coastguard Worker .input_width(3)
2914*4bdc9457SAndroid Build Coastguard Worker .next_input_height(6)
2915*4bdc9457SAndroid Build Coastguard Worker .next_input_width(5)
2916*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
2917*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
2918*4bdc9457SAndroid Build Coastguard Worker .channels(24)
2919*4bdc9457SAndroid Build Coastguard Worker .TestSetupQU8();
2920*4bdc9457SAndroid Build Coastguard Worker }
2921*4bdc9457SAndroid Build Coastguard Worker
2922*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass ****************************/
2923*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool)2924*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool) {
2925*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2926*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
2927*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2928*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2929*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
2930*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
2931*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2932*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2933*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2934*4bdc9457SAndroid Build Coastguard Worker .TestF16();
2935*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2936*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
2937*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
2938*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2939*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2940*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2941*4bdc9457SAndroid Build Coastguard Worker .TestF16();
2942*4bdc9457SAndroid Build Coastguard Worker }
2943*4bdc9457SAndroid Build Coastguard Worker }
2944*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_stride)2945*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_stride) {
2946*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2947*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
2948*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2949*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
2950*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
2951*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
2952*4bdc9457SAndroid Build Coastguard Worker continue;
2953*4bdc9457SAndroid Build Coastguard Worker }
2954*4bdc9457SAndroid Build Coastguard Worker
2955*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2956*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
2957*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
2958*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2959*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2960*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
2961*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
2962*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2963*4bdc9457SAndroid Build Coastguard Worker .TestF16();
2964*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2965*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
2966*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
2967*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
2968*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
2969*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
2970*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
2971*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2972*4bdc9457SAndroid Build Coastguard Worker .TestF16();
2973*4bdc9457SAndroid Build Coastguard Worker }
2974*4bdc9457SAndroid Build Coastguard Worker }
2975*4bdc9457SAndroid Build Coastguard Worker }
2976*4bdc9457SAndroid Build Coastguard Worker }
2977*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_width_padding)2978*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_width_padding) {
2979*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2980*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
2981*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
2982*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
2983*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
2984*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
2985*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2986*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
2987*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
2988*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2989*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
2990*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
2991*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
2992*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
2993*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
2994*4bdc9457SAndroid Build Coastguard Worker .TestF16();
2995*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
2996*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
2997*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
2998*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
2999*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3000*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3001*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3002*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3003*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3004*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3005*4bdc9457SAndroid Build Coastguard Worker }
3006*4bdc9457SAndroid Build Coastguard Worker }
3007*4bdc9457SAndroid Build Coastguard Worker }
3008*4bdc9457SAndroid Build Coastguard Worker }
3009*4bdc9457SAndroid Build Coastguard Worker }
3010*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_height_padding)3011*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_height_padding) {
3012*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3013*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3014*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3015*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3016*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
3017*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
3018*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3019*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3020*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3021*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3022*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3023*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3024*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3025*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3026*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3027*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3028*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3029*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3030*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3031*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3032*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3033*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3034*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3035*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3036*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3037*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3038*4bdc9457SAndroid Build Coastguard Worker }
3039*4bdc9457SAndroid Build Coastguard Worker }
3040*4bdc9457SAndroid Build Coastguard Worker }
3041*4bdc9457SAndroid Build Coastguard Worker }
3042*4bdc9457SAndroid Build Coastguard Worker }
3043*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_tf_same_padding)3044*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_tf_same_padding) {
3045*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3046*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3047*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3048*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3049*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
3050*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3051*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3052*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3053*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3054*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3055*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3056*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3057*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3058*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3059*4bdc9457SAndroid Build Coastguard Worker }
3060*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
3061*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3062*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3063*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3064*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3065*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3066*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3067*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3068*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3069*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3070*4bdc9457SAndroid Build Coastguard Worker }
3071*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
3072*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3073*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3074*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3075*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3076*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3077*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3078*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3079*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3080*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3081*4bdc9457SAndroid Build Coastguard Worker }
3082*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
3083*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3084*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3085*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3086*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3087*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3088*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3089*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3090*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3091*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3092*4bdc9457SAndroid Build Coastguard Worker }
3093*4bdc9457SAndroid Build Coastguard Worker }
3094*4bdc9457SAndroid Build Coastguard Worker }
3095*4bdc9457SAndroid Build Coastguard Worker }
3096*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_input_stride)3097*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_input_stride) {
3098*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3099*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3100*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3101*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3102*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3103*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3104*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3105*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3106*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3107*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3108*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3109*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3110*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3111*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3112*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3113*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3114*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3115*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3116*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3117*4bdc9457SAndroid Build Coastguard Worker }
3118*4bdc9457SAndroid Build Coastguard Worker }
3119*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_output_stride)3120*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_output_stride) {
3121*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3122*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3123*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3124*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3125*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3126*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3127*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3128*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3129*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3130*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3131*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3132*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3133*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3134*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3135*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3136*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3137*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3138*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3139*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3140*4bdc9457SAndroid Build Coastguard Worker }
3141*4bdc9457SAndroid Build Coastguard Worker }
3142*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_qmin)3143*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_qmin) {
3144*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3145*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3146*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3147*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3148*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3149*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3150*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3151*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3152*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3153*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3154*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3155*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3156*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3157*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3158*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3159*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3160*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3161*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3162*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3163*4bdc9457SAndroid Build Coastguard Worker }
3164*4bdc9457SAndroid Build Coastguard Worker }
3165*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_pool_with_qmax)3166*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_pool_with_qmax) {
3167*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3168*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3169*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3170*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3171*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3172*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3173*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3174*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3175*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3176*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3177*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3178*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3179*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3180*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3181*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3182*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3183*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3184*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3185*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3186*4bdc9457SAndroid Build Coastguard Worker }
3187*4bdc9457SAndroid Build Coastguard Worker }
3188*4bdc9457SAndroid Build Coastguard Worker
3189*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass, batched ****************************/
3190*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool)3191*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool) {
3192*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3193*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3194*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3195*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3196*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3197*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3198*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3199*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3200*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3201*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3202*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3203*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3204*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3205*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3206*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3207*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3208*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3209*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3210*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3211*4bdc9457SAndroid Build Coastguard Worker }
3212*4bdc9457SAndroid Build Coastguard Worker }
3213*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_stride)3214*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_stride) {
3215*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3216*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3217*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3218*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
3219*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
3220*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
3221*4bdc9457SAndroid Build Coastguard Worker continue;
3222*4bdc9457SAndroid Build Coastguard Worker }
3223*4bdc9457SAndroid Build Coastguard Worker
3224*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3225*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3226*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3227*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3228*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3229*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3230*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3231*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3232*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3233*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3234*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3235*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3236*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3237*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3238*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3239*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3240*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3241*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3242*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3243*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3244*4bdc9457SAndroid Build Coastguard Worker }
3245*4bdc9457SAndroid Build Coastguard Worker }
3246*4bdc9457SAndroid Build Coastguard Worker }
3247*4bdc9457SAndroid Build Coastguard Worker }
3248*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_width_padding)3249*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_width_padding) {
3250*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3251*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3252*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3253*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3254*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
3255*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
3256*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3257*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3258*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3259*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3260*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3261*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3262*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3263*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3264*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3265*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3266*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3267*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3268*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3269*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3270*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3271*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3272*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3273*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3274*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3275*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3276*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3277*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3278*4bdc9457SAndroid Build Coastguard Worker }
3279*4bdc9457SAndroid Build Coastguard Worker }
3280*4bdc9457SAndroid Build Coastguard Worker }
3281*4bdc9457SAndroid Build Coastguard Worker }
3282*4bdc9457SAndroid Build Coastguard Worker }
3283*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_height_padding)3284*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_height_padding) {
3285*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3286*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3287*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3288*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3289*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
3290*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
3291*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3292*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3293*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3294*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3295*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3296*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3297*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3298*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3299*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3300*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3301*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3302*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3303*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3304*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3305*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3306*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3307*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3308*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3309*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3310*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3311*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3312*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3313*4bdc9457SAndroid Build Coastguard Worker }
3314*4bdc9457SAndroid Build Coastguard Worker }
3315*4bdc9457SAndroid Build Coastguard Worker }
3316*4bdc9457SAndroid Build Coastguard Worker }
3317*4bdc9457SAndroid Build Coastguard Worker }
3318*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_tf_same_padding)3319*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_tf_same_padding) {
3320*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3321*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3322*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3323*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3324*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
3325*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3326*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3327*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3328*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3329*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3330*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3331*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3332*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3333*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3334*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3335*4bdc9457SAndroid Build Coastguard Worker }
3336*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
3337*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3338*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3339*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3340*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3341*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3342*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3343*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3344*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3345*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3346*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3347*4bdc9457SAndroid Build Coastguard Worker }
3348*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
3349*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3350*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3351*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3352*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3353*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3354*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3355*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3356*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3357*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3358*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3359*4bdc9457SAndroid Build Coastguard Worker }
3360*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
3361*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3362*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3363*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3364*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3365*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3366*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3367*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3368*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3369*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3370*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3371*4bdc9457SAndroid Build Coastguard Worker }
3372*4bdc9457SAndroid Build Coastguard Worker }
3373*4bdc9457SAndroid Build Coastguard Worker }
3374*4bdc9457SAndroid Build Coastguard Worker }
3375*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_input_stride)3376*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_input_stride) {
3377*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3378*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3379*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3380*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3381*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3382*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3383*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3384*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3385*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3386*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3387*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3388*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3389*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3390*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3391*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3392*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3393*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3394*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3395*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3396*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3397*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3398*4bdc9457SAndroid Build Coastguard Worker }
3399*4bdc9457SAndroid Build Coastguard Worker }
3400*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_output_stride)3401*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_output_stride) {
3402*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3403*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3404*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3405*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3406*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3407*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3408*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3409*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3410*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3411*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3412*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3413*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3414*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3415*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3416*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3417*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3418*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3419*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3420*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3421*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3422*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3423*4bdc9457SAndroid Build Coastguard Worker }
3424*4bdc9457SAndroid Build Coastguard Worker }
3425*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_qmin)3426*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_qmin) {
3427*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3428*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3429*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3430*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3431*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3432*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3433*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3434*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3435*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3436*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3437*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3438*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3439*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3440*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3441*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3442*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3443*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3444*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3445*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3446*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3447*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3448*4bdc9457SAndroid Build Coastguard Worker }
3449*4bdc9457SAndroid Build Coastguard Worker }
3450*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_pool_with_qmax)3451*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_pool_with_qmax) {
3452*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3453*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
3454*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3455*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3456*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3457*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3458*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3459*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3460*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3461*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3462*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3463*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3464*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3465*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3466*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3467*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3468*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3469*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3470*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3471*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3472*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3473*4bdc9457SAndroid Build Coastguard Worker }
3474*4bdc9457SAndroid Build Coastguard Worker }
3475*4bdc9457SAndroid Build Coastguard Worker
3476*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass ****************************/
3477*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool)3478*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool) {
3479*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3480*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.avgpool.primary_tile * 2);
3481*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3482*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3483*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3484*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3485*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3486*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3487*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3488*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3489*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3490*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3491*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3492*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3493*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3494*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3495*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3496*4bdc9457SAndroid Build Coastguard Worker }
3497*4bdc9457SAndroid Build Coastguard Worker }
3498*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_stride)3499*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_stride) {
3500*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3501*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3502*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3503*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
3504*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
3505*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
3506*4bdc9457SAndroid Build Coastguard Worker continue;
3507*4bdc9457SAndroid Build Coastguard Worker }
3508*4bdc9457SAndroid Build Coastguard Worker
3509*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3510*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3511*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3512*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3513*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3514*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3515*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3516*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3517*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3518*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3519*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3520*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3521*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3522*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3523*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3524*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3525*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3526*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3527*4bdc9457SAndroid Build Coastguard Worker }
3528*4bdc9457SAndroid Build Coastguard Worker }
3529*4bdc9457SAndroid Build Coastguard Worker }
3530*4bdc9457SAndroid Build Coastguard Worker }
3531*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_width_padding)3532*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_width_padding) {
3533*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3534*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3535*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3536*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3537*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
3538*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3539*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3540*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3541*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3542*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3543*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3544*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3545*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3546*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3547*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3548*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3549*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3550*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3551*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3552*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3553*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3554*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3555*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3556*4bdc9457SAndroid Build Coastguard Worker }
3557*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
3558*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3559*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3560*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3561*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3562*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3563*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3564*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3565*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3566*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3567*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3568*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3569*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3570*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3571*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3572*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3573*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3574*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3575*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3576*4bdc9457SAndroid Build Coastguard Worker }
3577*4bdc9457SAndroid Build Coastguard Worker }
3578*4bdc9457SAndroid Build Coastguard Worker }
3579*4bdc9457SAndroid Build Coastguard Worker }
3580*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_height_padding)3581*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_height_padding) {
3582*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3583*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3584*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3585*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3586*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
3587*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
3588*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3589*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3590*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3591*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3592*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3593*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3594*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3595*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3596*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3597*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3598*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3599*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3600*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3601*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3602*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3603*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3604*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3605*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3606*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3607*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3608*4bdc9457SAndroid Build Coastguard Worker }
3609*4bdc9457SAndroid Build Coastguard Worker }
3610*4bdc9457SAndroid Build Coastguard Worker }
3611*4bdc9457SAndroid Build Coastguard Worker }
3612*4bdc9457SAndroid Build Coastguard Worker }
3613*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_tf_same_padding)3614*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_tf_same_padding) {
3615*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3616*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3617*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3618*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3619*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
3620*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3621*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3622*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3623*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3624*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3625*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3626*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3627*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3628*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3629*4bdc9457SAndroid Build Coastguard Worker }
3630*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
3631*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3632*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3633*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3634*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3635*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3636*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3637*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3638*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3639*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3640*4bdc9457SAndroid Build Coastguard Worker }
3641*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
3642*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3643*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3644*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3645*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3646*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3647*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3648*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3649*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3650*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3651*4bdc9457SAndroid Build Coastguard Worker }
3652*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
3653*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3654*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3655*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3656*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3657*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3658*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3659*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3660*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3661*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3662*4bdc9457SAndroid Build Coastguard Worker }
3663*4bdc9457SAndroid Build Coastguard Worker }
3664*4bdc9457SAndroid Build Coastguard Worker }
3665*4bdc9457SAndroid Build Coastguard Worker }
3666*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_input_stride)3667*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_input_stride) {
3668*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3669*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3670*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3671*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3672*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3673*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3674*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3675*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3676*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3677*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3678*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3679*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3680*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3681*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3682*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3683*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3684*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3685*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3686*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3687*4bdc9457SAndroid Build Coastguard Worker }
3688*4bdc9457SAndroid Build Coastguard Worker }
3689*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_output_stride)3690*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_output_stride) {
3691*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3692*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3693*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3694*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3695*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3696*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3697*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3698*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3699*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3700*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3701*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3702*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3703*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3704*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3705*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3706*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3707*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3708*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3709*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3710*4bdc9457SAndroid Build Coastguard Worker }
3711*4bdc9457SAndroid Build Coastguard Worker }
3712*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_qmin)3713*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_qmin) {
3714*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3715*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3716*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3717*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3718*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3719*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3720*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3721*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3722*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3723*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3724*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3725*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3726*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3727*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3728*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3729*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3730*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3731*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3732*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3733*4bdc9457SAndroid Build Coastguard Worker }
3734*4bdc9457SAndroid Build Coastguard Worker }
3735*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_pool_with_qmax)3736*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_pool_with_qmax) {
3737*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3738*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3739*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3740*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3741*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3742*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3743*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3744*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3745*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3746*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3747*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3748*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3749*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3750*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3751*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3752*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3753*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3754*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3755*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3756*4bdc9457SAndroid Build Coastguard Worker }
3757*4bdc9457SAndroid Build Coastguard Worker }
3758*4bdc9457SAndroid Build Coastguard Worker
3759*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass, batched ****************************/
3760*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool)3761*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool) {
3762*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3763*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.avgpool.primary_tile * 2);
3764*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3765*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3766*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3767*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3768*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3769*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3770*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3771*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3772*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3773*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3774*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3775*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3776*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3777*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3778*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3779*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3780*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3781*4bdc9457SAndroid Build Coastguard Worker }
3782*4bdc9457SAndroid Build Coastguard Worker }
3783*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_stride)3784*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_stride) {
3785*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3786*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3787*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3788*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
3789*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
3790*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
3791*4bdc9457SAndroid Build Coastguard Worker continue;
3792*4bdc9457SAndroid Build Coastguard Worker }
3793*4bdc9457SAndroid Build Coastguard Worker
3794*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3795*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3796*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3797*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3798*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3799*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3800*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3801*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3802*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3803*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3804*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3805*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3806*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3807*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3808*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3809*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3810*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
3811*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
3812*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3813*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3814*4bdc9457SAndroid Build Coastguard Worker }
3815*4bdc9457SAndroid Build Coastguard Worker }
3816*4bdc9457SAndroid Build Coastguard Worker }
3817*4bdc9457SAndroid Build Coastguard Worker }
3818*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_width_padding)3819*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_width_padding) {
3820*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3821*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3822*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3823*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3824*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
3825*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
3826*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3827*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3828*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3829*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3830*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3831*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3832*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3833*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3834*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3835*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3836*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3837*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3838*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3839*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3840*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3841*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
3842*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
3843*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3844*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3845*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3846*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3847*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3848*4bdc9457SAndroid Build Coastguard Worker }
3849*4bdc9457SAndroid Build Coastguard Worker }
3850*4bdc9457SAndroid Build Coastguard Worker }
3851*4bdc9457SAndroid Build Coastguard Worker }
3852*4bdc9457SAndroid Build Coastguard Worker }
3853*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_height_padding)3854*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_height_padding) {
3855*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3856*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3857*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3858*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3859*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
3860*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
3861*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3862*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3863*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3864*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3865*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3866*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3867*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3868*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3869*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3870*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3871*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3872*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3873*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3874*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3875*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3876*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
3877*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
3878*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3879*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3880*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3881*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3882*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3883*4bdc9457SAndroid Build Coastguard Worker }
3884*4bdc9457SAndroid Build Coastguard Worker }
3885*4bdc9457SAndroid Build Coastguard Worker }
3886*4bdc9457SAndroid Build Coastguard Worker }
3887*4bdc9457SAndroid Build Coastguard Worker }
3888*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_tf_same_padding)3889*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_tf_same_padding) {
3890*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3891*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3892*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3893*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
3894*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
3895*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3896*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3897*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3898*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3899*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3900*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3901*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3902*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3903*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3904*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3905*4bdc9457SAndroid Build Coastguard Worker }
3906*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
3907*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3908*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3909*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3910*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3911*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3912*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3913*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3914*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3915*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3916*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3917*4bdc9457SAndroid Build Coastguard Worker }
3918*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
3919*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3920*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3921*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
3922*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3923*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3924*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3925*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3926*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3927*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3928*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3929*4bdc9457SAndroid Build Coastguard Worker }
3930*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
3931*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3932*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3933*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3934*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
3935*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3936*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3937*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3938*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
3939*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3940*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3941*4bdc9457SAndroid Build Coastguard Worker }
3942*4bdc9457SAndroid Build Coastguard Worker }
3943*4bdc9457SAndroid Build Coastguard Worker }
3944*4bdc9457SAndroid Build Coastguard Worker }
3945*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_input_stride)3946*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_input_stride) {
3947*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3948*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3949*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3950*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3951*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3952*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3953*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3954*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3955*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3956*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3957*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3958*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3959*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3960*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3961*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3962*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3963*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3964*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3965*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3966*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
3967*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3968*4bdc9457SAndroid Build Coastguard Worker }
3969*4bdc9457SAndroid Build Coastguard Worker }
3970*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_output_stride)3971*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_output_stride) {
3972*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3973*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3974*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
3975*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3976*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3977*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
3978*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
3979*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
3980*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
3981*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3982*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3983*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3984*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
3985*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
3986*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
3987*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
3988*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
3989*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
3990*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
3991*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
3992*4bdc9457SAndroid Build Coastguard Worker .TestF16();
3993*4bdc9457SAndroid Build Coastguard Worker }
3994*4bdc9457SAndroid Build Coastguard Worker }
3995*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_qmin)3996*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_qmin) {
3997*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3998*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
3999*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4000*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4001*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4002*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
4003*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
4004*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4005*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4006*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4007*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4008*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4009*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4010*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4011*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
4012*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
4013*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4014*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4015*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4016*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4017*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4018*4bdc9457SAndroid Build Coastguard Worker }
4019*4bdc9457SAndroid Build Coastguard Worker }
4020*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_pool_with_qmax)4021*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_pool_with_qmax) {
4022*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4023*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4024*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4025*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4026*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4027*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
4028*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
4029*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4030*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4031*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4032*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4033*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4034*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4035*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4036*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
4037*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
4038*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4039*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4040*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4041*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4042*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4043*4bdc9457SAndroid Build Coastguard Worker }
4044*4bdc9457SAndroid Build Coastguard Worker }
4045*4bdc9457SAndroid Build Coastguard Worker
4046*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass ****************************/
4047*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image)4048*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image) {
4049*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4050*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4051*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4052*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4053*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4054*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4055*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4056*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4057*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4058*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4059*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4060*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4061*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4062*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4063*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4064*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4065*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4066*4bdc9457SAndroid Build Coastguard Worker }
4067*4bdc9457SAndroid Build Coastguard Worker }
4068*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_width_padding)4069*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_width_padding) {
4070*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4071*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4072*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4073*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
4074*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4075*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4076*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
4077*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4078*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4079*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4080*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4081*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4082*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4083*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4084*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
4085*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4086*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4087*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4088*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4089*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4090*4bdc9457SAndroid Build Coastguard Worker
4091*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
4092*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4093*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4094*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
4095*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4096*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4097*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4098*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4099*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4100*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4101*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4102*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
4103*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4104*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4105*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4106*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4107*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4108*4bdc9457SAndroid Build Coastguard Worker }
4109*4bdc9457SAndroid Build Coastguard Worker }
4110*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_height_padding)4111*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_height_padding) {
4112*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4113*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4114*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4115*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
4116*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4117*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
4118*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4119*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4120*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4121*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4122*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4123*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4124*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4125*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
4126*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4127*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4128*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4129*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4130*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4131*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4132*4bdc9457SAndroid Build Coastguard Worker
4133*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
4134*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4135*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
4136*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4137*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4138*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4139*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4140*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4141*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4142*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4143*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
4144*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4145*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4146*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4147*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4148*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4149*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4150*4bdc9457SAndroid Build Coastguard Worker }
4151*4bdc9457SAndroid Build Coastguard Worker }
4152*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_input_stride)4153*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_input_stride) {
4154*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4155*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4156*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4157*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4158*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4159*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4160*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4161*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4162*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4163*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4164*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4165*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4166*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4167*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4168*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4169*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4170*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4171*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4172*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4173*4bdc9457SAndroid Build Coastguard Worker }
4174*4bdc9457SAndroid Build Coastguard Worker }
4175*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_output_stride)4176*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_output_stride) {
4177*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4178*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4179*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4180*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4181*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4182*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4183*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4184*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4185*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4186*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4187*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4188*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4189*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4190*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4191*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4192*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4193*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4194*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4195*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4196*4bdc9457SAndroid Build Coastguard Worker }
4197*4bdc9457SAndroid Build Coastguard Worker }
4198*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_qmin)4199*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_qmin) {
4200*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4201*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4202*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4203*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4204*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4205*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4206*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4207*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4208*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4209*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4210*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4211*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4212*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4213*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4214*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4215*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4216*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4217*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4218*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4219*4bdc9457SAndroid Build Coastguard Worker }
4220*4bdc9457SAndroid Build Coastguard Worker }
4221*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,small_image_with_qmax)4222*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, small_image_with_qmax) {
4223*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4224*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4225*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4226*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4227*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4228*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4229*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4230*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4231*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4232*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4233*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4234*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4235*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4236*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4237*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4238*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4239*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4240*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4241*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4242*4bdc9457SAndroid Build Coastguard Worker }
4243*4bdc9457SAndroid Build Coastguard Worker }
4244*4bdc9457SAndroid Build Coastguard Worker
4245*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass, batched ****************************/
4246*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image)4247*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image) {
4248*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4249*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4250*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4251*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4252*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4253*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4254*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4255*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4256*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4257*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4258*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4259*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4260*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4261*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4262*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4263*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4264*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4265*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4266*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4267*4bdc9457SAndroid Build Coastguard Worker }
4268*4bdc9457SAndroid Build Coastguard Worker }
4269*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_width_padding)4270*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_width_padding) {
4271*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4272*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4273*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4274*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
4275*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4276*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4277*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4278*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
4279*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4280*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4281*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4282*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4283*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4284*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4285*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4286*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4287*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
4288*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4289*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4290*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4291*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4292*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4293*4bdc9457SAndroid Build Coastguard Worker
4294*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
4295*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4296*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4297*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4298*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
4299*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4300*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4301*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4302*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4303*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4304*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4305*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4306*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4307*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
4308*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4309*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4310*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4311*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4312*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4313*4bdc9457SAndroid Build Coastguard Worker }
4314*4bdc9457SAndroid Build Coastguard Worker }
4315*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_height_padding)4316*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_height_padding) {
4317*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4318*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4319*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4320*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
4321*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4322*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4323*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
4324*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4325*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4326*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4327*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4328*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4329*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4330*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4331*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4332*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
4333*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4334*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4335*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4336*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4337*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4338*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4339*4bdc9457SAndroid Build Coastguard Worker
4340*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
4341*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4342*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4343*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
4344*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4345*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4346*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4347*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4348*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4349*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4350*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4351*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4352*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
4353*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4354*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4355*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4356*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4357*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4358*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4359*4bdc9457SAndroid Build Coastguard Worker }
4360*4bdc9457SAndroid Build Coastguard Worker }
4361*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_input_stride)4362*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_input_stride) {
4363*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4364*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4365*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4366*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4367*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4368*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4369*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4370*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4371*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4372*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4373*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4374*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4375*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4376*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4377*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4378*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4379*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4380*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4381*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4382*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4383*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4384*4bdc9457SAndroid Build Coastguard Worker }
4385*4bdc9457SAndroid Build Coastguard Worker }
4386*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_output_stride)4387*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_output_stride) {
4388*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4389*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4390*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4391*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4392*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4393*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4394*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4395*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4396*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4397*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4398*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4399*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4400*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4401*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4402*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4403*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4404*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4405*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4406*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4407*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4408*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4409*4bdc9457SAndroid Build Coastguard Worker }
4410*4bdc9457SAndroid Build Coastguard Worker }
4411*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_qmin)4412*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_qmin) {
4413*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4414*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4415*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4416*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4417*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4418*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4419*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4420*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4421*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4422*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4423*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4424*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4425*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4426*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4427*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4428*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4429*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4430*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4431*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4432*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4433*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4434*4bdc9457SAndroid Build Coastguard Worker }
4435*4bdc9457SAndroid Build Coastguard Worker }
4436*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_small_image_with_qmax)4437*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_small_image_with_qmax) {
4438*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4439*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
4440*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4441*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4442*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4443*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4444*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4445*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4446*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4447*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4448*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4449*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4450*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4451*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4452*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4453*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4454*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4455*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4456*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4457*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4458*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4459*4bdc9457SAndroid Build Coastguard Worker }
4460*4bdc9457SAndroid Build Coastguard Worker }
4461*4bdc9457SAndroid Build Coastguard Worker
4462*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass ****************************/
4463*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image)4464*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image) {
4465*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4466*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4467*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4468*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4469*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4470*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4471*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4472*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4473*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4474*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4475*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4476*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4477*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4478*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4479*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4480*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4481*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4482*4bdc9457SAndroid Build Coastguard Worker }
4483*4bdc9457SAndroid Build Coastguard Worker }
4484*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_width_padding)4485*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_width_padding) {
4486*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4487*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4488*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4489*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
4490*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4491*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4492*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
4493*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
4494*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4495*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4496*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4497*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4498*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4499*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4500*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
4501*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
4502*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4503*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4504*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4505*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4506*4bdc9457SAndroid Build Coastguard Worker }
4507*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
4508*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4509*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4510*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
4511*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
4512*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4513*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4514*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4515*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4516*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4517*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4518*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
4519*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
4520*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4521*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4522*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4523*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4524*4bdc9457SAndroid Build Coastguard Worker }
4525*4bdc9457SAndroid Build Coastguard Worker }
4526*4bdc9457SAndroid Build Coastguard Worker }
4527*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_height_padding)4528*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_height_padding) {
4529*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4530*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4531*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4532*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 1; padding_top <= 2; padding_top++) {
4533*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4534*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
4535*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4536*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
4537*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4538*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4539*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4540*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4541*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4542*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
4543*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4544*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
4545*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4546*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4547*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4548*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4549*4bdc9457SAndroid Build Coastguard Worker }
4550*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 1; padding_bottom <= 2; padding_bottom++) {
4551*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4552*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
4553*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4554*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
4555*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4556*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4557*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4558*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4559*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4560*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
4561*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4562*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
4563*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4564*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4565*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4566*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4567*4bdc9457SAndroid Build Coastguard Worker }
4568*4bdc9457SAndroid Build Coastguard Worker }
4569*4bdc9457SAndroid Build Coastguard Worker }
4570*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_input_stride)4571*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_input_stride) {
4572*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4573*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4574*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4575*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4576*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4577*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4578*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4579*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4580*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4581*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4582*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4583*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4584*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4585*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4586*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4587*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4588*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4589*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4590*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4591*4bdc9457SAndroid Build Coastguard Worker }
4592*4bdc9457SAndroid Build Coastguard Worker }
4593*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_output_stride)4594*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_output_stride) {
4595*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4596*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4597*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4598*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4599*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4600*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4601*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4602*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4603*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4604*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4605*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4606*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4607*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4608*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4609*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4610*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4611*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4612*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4613*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4614*4bdc9457SAndroid Build Coastguard Worker }
4615*4bdc9457SAndroid Build Coastguard Worker }
4616*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_qmin)4617*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_qmin) {
4618*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4619*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4620*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4621*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4622*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4623*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4624*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4625*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4626*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4627*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4628*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4629*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4630*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4631*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4632*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4633*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4634*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4635*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4636*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4637*4bdc9457SAndroid Build Coastguard Worker }
4638*4bdc9457SAndroid Build Coastguard Worker }
4639*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,large_image_with_qmax)4640*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, large_image_with_qmax) {
4641*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4642*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4643*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4644*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4645*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4646*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4647*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4648*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4649*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4650*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4651*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4652*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4653*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4654*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4655*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4656*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4657*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4658*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4659*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4660*4bdc9457SAndroid Build Coastguard Worker }
4661*4bdc9457SAndroid Build Coastguard Worker }
4662*4bdc9457SAndroid Build Coastguard Worker
4663*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass, batched ****************************/
4664*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image)4665*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image) {
4666*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4667*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4668*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4669*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4670*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4671*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4672*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4673*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4674*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4675*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4676*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4677*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4678*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4679*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4680*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4681*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4682*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4683*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4684*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4685*4bdc9457SAndroid Build Coastguard Worker }
4686*4bdc9457SAndroid Build Coastguard Worker }
4687*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_width_padding)4688*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_width_padding) {
4689*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4690*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4691*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4692*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
4693*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4694*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4695*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4696*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
4697*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
4698*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4699*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4700*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4701*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4702*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4703*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4704*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4705*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
4706*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
4707*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4708*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4709*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4710*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4711*4bdc9457SAndroid Build Coastguard Worker }
4712*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
4713*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4714*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4715*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4716*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
4717*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
4718*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4719*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4720*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4721*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4722*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4723*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4724*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4725*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
4726*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
4727*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4728*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4729*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4730*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4731*4bdc9457SAndroid Build Coastguard Worker }
4732*4bdc9457SAndroid Build Coastguard Worker }
4733*4bdc9457SAndroid Build Coastguard Worker }
4734*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_height_padding)4735*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_height_padding) {
4736*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4737*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4738*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4739*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
4740*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4741*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4742*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
4743*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4744*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
4745*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4746*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4747*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4748*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4749*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4750*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4751*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
4752*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4753*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
4754*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4755*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4756*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4757*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4758*4bdc9457SAndroid Build Coastguard Worker }
4759*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 1; padding_bottom <= 2; padding_bottom++) {
4760*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4761*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4762*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
4763*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4764*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
4765*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4766*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4767*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4768*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4769*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4770*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4771*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
4772*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4773*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
4774*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4775*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4776*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4777*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4778*4bdc9457SAndroid Build Coastguard Worker }
4779*4bdc9457SAndroid Build Coastguard Worker }
4780*4bdc9457SAndroid Build Coastguard Worker }
4781*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_input_stride)4782*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_input_stride) {
4783*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4784*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4785*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4786*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4787*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4788*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4789*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4790*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4791*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4792*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4793*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4794*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4795*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4796*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4797*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4798*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4799*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4800*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4801*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4802*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
4803*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4804*4bdc9457SAndroid Build Coastguard Worker }
4805*4bdc9457SAndroid Build Coastguard Worker }
4806*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_output_stride)4807*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_output_stride) {
4808*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4809*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4810*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4811*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4812*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4813*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4814*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4815*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4816*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4817*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4818*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4819*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4820*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4821*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4822*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4823*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4824*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4825*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4826*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4827*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
4828*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4829*4bdc9457SAndroid Build Coastguard Worker }
4830*4bdc9457SAndroid Build Coastguard Worker }
4831*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_qmin)4832*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_qmin) {
4833*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4834*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4835*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4836*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4837*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4838*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4839*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4840*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4841*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4842*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4843*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4844*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4845*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4846*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4847*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4848*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4849*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4850*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4851*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4852*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4853*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4854*4bdc9457SAndroid Build Coastguard Worker }
4855*4bdc9457SAndroid Build Coastguard Worker }
4856*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,batched_large_image_with_qmax)4857*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, batched_large_image_with_qmax) {
4858*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4859*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
4860*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
4861*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4862*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4863*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
4864*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
4865*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
4866*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
4867*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4868*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4869*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4870*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4871*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4872*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
4873*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
4874*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
4875*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
4876*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
4877*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4878*4bdc9457SAndroid Build Coastguard Worker .TestF16();
4879*4bdc9457SAndroid Build Coastguard Worker }
4880*4bdc9457SAndroid Build Coastguard Worker }
4881*4bdc9457SAndroid Build Coastguard Worker
4882*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, setup ****************************/
4883*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_increasing_batch)4884*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_increasing_batch) {
4885*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4886*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4887*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4888*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
4889*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4890*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4891*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4892*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4893*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4894*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4895*4bdc9457SAndroid Build Coastguard Worker }
4896*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_decreasing_batch)4897*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_decreasing_batch) {
4898*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4899*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4900*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
4901*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(2)
4902*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4903*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4904*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4905*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4906*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4907*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4908*4bdc9457SAndroid Build Coastguard Worker }
4909*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_changing_height)4910*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_changing_height) {
4911*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4912*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4913*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4914*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4915*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4916*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
4917*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4918*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4919*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4920*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4921*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4922*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4923*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4924*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4925*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
4926*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4927*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4928*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4929*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4930*4bdc9457SAndroid Build Coastguard Worker }
4931*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_changing_width)4932*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_changing_width) {
4933*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4934*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4935*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4936*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4937*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4938*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
4939*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4940*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4941*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4942*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4943*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4944*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4945*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
4946*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4947*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
4948*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4949*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4950*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4951*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4952*4bdc9457SAndroid Build Coastguard Worker }
4953*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_swap_height_and_width)4954*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_swap_height_and_width) {
4955*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4956*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4957*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4958*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
4959*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
4960*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
4961*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
4962*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4963*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4964*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4965*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4966*4bdc9457SAndroid Build Coastguard Worker }
4967*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_local_to_global)4968*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_local_to_global) {
4969*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4970*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4971*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4972*4bdc9457SAndroid Build Coastguard Worker .input_height(6)
4973*4bdc9457SAndroid Build Coastguard Worker .input_width(5)
4974*4bdc9457SAndroid Build Coastguard Worker .next_input_height(5)
4975*4bdc9457SAndroid Build Coastguard Worker .next_input_width(3)
4976*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4977*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4978*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4979*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4980*4bdc9457SAndroid Build Coastguard Worker }
4981*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F16,setup_global_to_local)4982*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F16, setup_global_to_local) {
4983*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
4984*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
4985*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
4986*4bdc9457SAndroid Build Coastguard Worker .input_height(5)
4987*4bdc9457SAndroid Build Coastguard Worker .input_width(3)
4988*4bdc9457SAndroid Build Coastguard Worker .next_input_height(6)
4989*4bdc9457SAndroid Build Coastguard Worker .next_input_width(5)
4990*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
4991*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
4992*4bdc9457SAndroid Build Coastguard Worker .channels(24)
4993*4bdc9457SAndroid Build Coastguard Worker .TestSetupF16();
4994*4bdc9457SAndroid Build Coastguard Worker }
4995*4bdc9457SAndroid Build Coastguard Worker
4996*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass ****************************/
4997*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool)4998*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool) {
4999*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5000*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5001*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5002*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5003*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5004*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5005*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5006*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5007*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5008*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5009*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5010*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5011*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5012*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5013*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5014*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5015*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5016*4bdc9457SAndroid Build Coastguard Worker }
5017*4bdc9457SAndroid Build Coastguard Worker }
5018*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_stride)5019*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_stride) {
5020*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5021*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5022*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5023*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
5024*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
5025*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
5026*4bdc9457SAndroid Build Coastguard Worker continue;
5027*4bdc9457SAndroid Build Coastguard Worker }
5028*4bdc9457SAndroid Build Coastguard Worker
5029*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5030*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5031*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5032*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5033*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5034*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5035*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5036*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5037*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5038*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5039*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5040*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5041*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5042*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5043*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5044*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5045*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5046*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5047*4bdc9457SAndroid Build Coastguard Worker }
5048*4bdc9457SAndroid Build Coastguard Worker }
5049*4bdc9457SAndroid Build Coastguard Worker }
5050*4bdc9457SAndroid Build Coastguard Worker }
5051*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_width_padding)5052*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_width_padding) {
5053*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5054*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5055*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5056*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5057*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
5058*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
5059*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5060*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5061*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5062*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5063*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5064*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5065*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5066*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5067*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5068*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5069*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5070*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5071*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5072*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5073*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5074*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5075*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5076*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5077*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5078*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5079*4bdc9457SAndroid Build Coastguard Worker }
5080*4bdc9457SAndroid Build Coastguard Worker }
5081*4bdc9457SAndroid Build Coastguard Worker }
5082*4bdc9457SAndroid Build Coastguard Worker }
5083*4bdc9457SAndroid Build Coastguard Worker }
5084*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_height_padding)5085*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_height_padding) {
5086*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5087*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5088*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5089*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5090*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
5091*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
5092*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5093*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5094*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5095*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5096*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5097*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5098*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5099*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5100*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5101*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5102*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5103*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5104*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5105*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5106*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5107*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5108*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5109*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5110*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5111*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5112*4bdc9457SAndroid Build Coastguard Worker }
5113*4bdc9457SAndroid Build Coastguard Worker }
5114*4bdc9457SAndroid Build Coastguard Worker }
5115*4bdc9457SAndroid Build Coastguard Worker }
5116*4bdc9457SAndroid Build Coastguard Worker }
5117*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_tf_same_padding)5118*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_tf_same_padding) {
5119*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5120*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5121*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5122*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5123*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
5124*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5125*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5126*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5127*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5128*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5129*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5130*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5131*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5132*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5133*4bdc9457SAndroid Build Coastguard Worker }
5134*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
5135*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5136*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5137*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5138*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5139*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5140*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5141*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5142*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5143*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5144*4bdc9457SAndroid Build Coastguard Worker }
5145*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
5146*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5147*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5148*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5149*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5150*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5151*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5152*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5153*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5154*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5155*4bdc9457SAndroid Build Coastguard Worker }
5156*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
5157*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5158*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5159*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5160*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5161*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5162*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5163*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5164*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5165*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5166*4bdc9457SAndroid Build Coastguard Worker }
5167*4bdc9457SAndroid Build Coastguard Worker }
5168*4bdc9457SAndroid Build Coastguard Worker }
5169*4bdc9457SAndroid Build Coastguard Worker }
5170*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_input_stride)5171*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_input_stride) {
5172*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5173*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5174*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5175*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5176*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5177*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5178*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5179*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5180*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5181*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5182*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5183*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5184*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5185*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5186*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5187*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5188*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5189*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5190*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5191*4bdc9457SAndroid Build Coastguard Worker }
5192*4bdc9457SAndroid Build Coastguard Worker }
5193*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_output_stride)5194*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_output_stride) {
5195*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5196*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5197*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5198*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5199*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5200*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5201*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5202*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5203*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5204*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5205*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5206*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5207*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5208*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5209*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5210*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5211*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5212*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5213*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5214*4bdc9457SAndroid Build Coastguard Worker }
5215*4bdc9457SAndroid Build Coastguard Worker }
5216*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_qmin)5217*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_qmin) {
5218*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5219*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5220*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5221*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5222*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5223*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5224*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5225*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5226*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5227*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5228*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5229*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5230*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5231*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5232*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5233*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5234*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5235*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5236*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5237*4bdc9457SAndroid Build Coastguard Worker }
5238*4bdc9457SAndroid Build Coastguard Worker }
5239*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_pool_with_qmax)5240*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_pool_with_qmax) {
5241*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5242*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5243*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5244*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5245*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5246*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5247*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5248*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5249*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5250*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5251*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5252*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5253*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5254*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5255*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5256*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5257*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5258*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5259*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5260*4bdc9457SAndroid Build Coastguard Worker }
5261*4bdc9457SAndroid Build Coastguard Worker }
5262*4bdc9457SAndroid Build Coastguard Worker
5263*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, unipass, batched ****************************/
5264*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool)5265*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool) {
5266*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5267*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5268*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5269*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5270*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5271*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5272*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5273*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5274*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5275*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5276*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5277*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5278*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5279*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5280*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5281*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5282*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5283*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5284*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5285*4bdc9457SAndroid Build Coastguard Worker }
5286*4bdc9457SAndroid Build Coastguard Worker }
5287*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_stride)5288*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_stride) {
5289*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5290*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5291*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5292*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
5293*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
5294*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
5295*4bdc9457SAndroid Build Coastguard Worker continue;
5296*4bdc9457SAndroid Build Coastguard Worker }
5297*4bdc9457SAndroid Build Coastguard Worker
5298*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5299*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5300*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5301*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5302*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5303*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5304*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5305*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5306*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5307*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5308*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5309*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5310*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5311*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5312*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5313*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5314*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5315*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5316*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5317*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5318*4bdc9457SAndroid Build Coastguard Worker }
5319*4bdc9457SAndroid Build Coastguard Worker }
5320*4bdc9457SAndroid Build Coastguard Worker }
5321*4bdc9457SAndroid Build Coastguard Worker }
5322*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_width_padding)5323*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_width_padding) {
5324*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5325*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5326*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5327*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5328*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
5329*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
5330*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5331*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5332*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5333*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5334*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5335*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5336*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5337*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5338*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5339*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5340*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5341*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5342*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5343*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5344*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5345*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5346*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5347*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5348*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5349*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5350*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5351*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5352*4bdc9457SAndroid Build Coastguard Worker }
5353*4bdc9457SAndroid Build Coastguard Worker }
5354*4bdc9457SAndroid Build Coastguard Worker }
5355*4bdc9457SAndroid Build Coastguard Worker }
5356*4bdc9457SAndroid Build Coastguard Worker }
5357*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_height_padding)5358*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_height_padding) {
5359*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5360*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5361*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5362*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5363*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
5364*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
5365*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5366*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5367*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5368*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5369*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5370*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5371*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5372*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5373*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5374*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5375*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5376*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5377*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5378*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5379*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5380*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5381*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5382*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5383*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5384*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5385*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5386*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5387*4bdc9457SAndroid Build Coastguard Worker }
5388*4bdc9457SAndroid Build Coastguard Worker }
5389*4bdc9457SAndroid Build Coastguard Worker }
5390*4bdc9457SAndroid Build Coastguard Worker }
5391*4bdc9457SAndroid Build Coastguard Worker }
5392*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_tf_same_padding)5393*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_tf_same_padding) {
5394*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5395*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5396*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5397*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5398*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
5399*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5400*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5401*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5402*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5403*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5404*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5405*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5406*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5407*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5408*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5409*4bdc9457SAndroid Build Coastguard Worker }
5410*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
5411*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5412*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5413*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5414*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5415*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5416*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5417*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5418*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5419*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5420*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5421*4bdc9457SAndroid Build Coastguard Worker }
5422*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
5423*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5424*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5425*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5426*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5427*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5428*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5429*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5430*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5431*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5432*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5433*4bdc9457SAndroid Build Coastguard Worker }
5434*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
5435*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5436*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5437*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5438*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5439*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5440*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5441*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5442*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5443*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5444*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5445*4bdc9457SAndroid Build Coastguard Worker }
5446*4bdc9457SAndroid Build Coastguard Worker }
5447*4bdc9457SAndroid Build Coastguard Worker }
5448*4bdc9457SAndroid Build Coastguard Worker }
5449*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_input_stride)5450*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_input_stride) {
5451*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5452*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5453*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5454*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5455*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5456*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5457*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5458*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5459*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5460*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5461*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5462*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5463*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5464*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5465*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5466*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5467*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5468*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5469*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5470*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5471*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5472*4bdc9457SAndroid Build Coastguard Worker }
5473*4bdc9457SAndroid Build Coastguard Worker }
5474*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_output_stride)5475*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_output_stride) {
5476*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5477*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5478*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5479*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5480*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5481*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5482*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5483*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5484*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5485*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5486*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5487*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5488*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5489*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5490*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5491*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5492*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5493*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5494*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5495*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5496*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5497*4bdc9457SAndroid Build Coastguard Worker }
5498*4bdc9457SAndroid Build Coastguard Worker }
5499*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_qmin)5500*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_qmin) {
5501*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5502*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5503*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5504*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5505*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5506*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5507*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5508*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5509*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5510*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5511*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5512*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5513*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5514*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5515*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5516*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5517*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5518*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5519*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5520*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5521*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5522*4bdc9457SAndroid Build Coastguard Worker }
5523*4bdc9457SAndroid Build Coastguard Worker }
5524*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_pool_with_qmax)5525*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_pool_with_qmax) {
5526*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5527*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.avgpool.primary_tile);
5528*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5529*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5530*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5531*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5532*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5533*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5534*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5535*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5536*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5537*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5538*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5539*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5540*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5541*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5542*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5543*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5544*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5545*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5546*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5547*4bdc9457SAndroid Build Coastguard Worker }
5548*4bdc9457SAndroid Build Coastguard Worker }
5549*4bdc9457SAndroid Build Coastguard Worker
5550*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass ****************************/
5551*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool)5552*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool) {
5553*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5554*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.avgpool.primary_tile * 2);
5555*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5556*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5557*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5558*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5559*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5560*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5561*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5562*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5563*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5564*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5565*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5566*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5567*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5568*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5569*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5570*4bdc9457SAndroid Build Coastguard Worker }
5571*4bdc9457SAndroid Build Coastguard Worker }
5572*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_stride)5573*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_stride) {
5574*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5575*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5576*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5577*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
5578*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
5579*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
5580*4bdc9457SAndroid Build Coastguard Worker continue;
5581*4bdc9457SAndroid Build Coastguard Worker }
5582*4bdc9457SAndroid Build Coastguard Worker
5583*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5584*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5585*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5586*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5587*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5588*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5589*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5590*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5591*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5592*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5593*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5594*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5595*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5596*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5597*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5598*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5599*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5600*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5601*4bdc9457SAndroid Build Coastguard Worker }
5602*4bdc9457SAndroid Build Coastguard Worker }
5603*4bdc9457SAndroid Build Coastguard Worker }
5604*4bdc9457SAndroid Build Coastguard Worker }
5605*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_width_padding)5606*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_width_padding) {
5607*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5608*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5609*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5610*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5611*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
5612*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5613*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5614*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5615*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5616*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5617*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5618*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5619*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5620*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5621*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5622*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5623*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5624*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5625*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5626*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5627*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5628*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5629*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5630*4bdc9457SAndroid Build Coastguard Worker }
5631*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
5632*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5633*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5634*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5635*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5636*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5637*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5638*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5639*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5640*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5641*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5642*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5643*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5644*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5645*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5646*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5647*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5648*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5649*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5650*4bdc9457SAndroid Build Coastguard Worker }
5651*4bdc9457SAndroid Build Coastguard Worker }
5652*4bdc9457SAndroid Build Coastguard Worker }
5653*4bdc9457SAndroid Build Coastguard Worker }
5654*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_height_padding)5655*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_height_padding) {
5656*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5657*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5658*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5659*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5660*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
5661*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
5662*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5663*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5664*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5665*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5666*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5667*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5668*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5669*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5670*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5671*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5672*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5673*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5674*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5675*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5676*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5677*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5678*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5679*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5680*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5681*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5682*4bdc9457SAndroid Build Coastguard Worker }
5683*4bdc9457SAndroid Build Coastguard Worker }
5684*4bdc9457SAndroid Build Coastguard Worker }
5685*4bdc9457SAndroid Build Coastguard Worker }
5686*4bdc9457SAndroid Build Coastguard Worker }
5687*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_tf_same_padding)5688*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_tf_same_padding) {
5689*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5690*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5691*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5692*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5693*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
5694*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5695*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5696*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5697*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5698*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5699*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5700*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5701*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5702*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5703*4bdc9457SAndroid Build Coastguard Worker }
5704*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
5705*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5706*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5707*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5708*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5709*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5710*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5711*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5712*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5713*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5714*4bdc9457SAndroid Build Coastguard Worker }
5715*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
5716*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5717*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5718*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5719*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5720*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5721*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5722*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5723*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5724*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5725*4bdc9457SAndroid Build Coastguard Worker }
5726*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
5727*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5728*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5729*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5730*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5731*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5732*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5733*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5734*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5735*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5736*4bdc9457SAndroid Build Coastguard Worker }
5737*4bdc9457SAndroid Build Coastguard Worker }
5738*4bdc9457SAndroid Build Coastguard Worker }
5739*4bdc9457SAndroid Build Coastguard Worker }
5740*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_input_stride)5741*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_input_stride) {
5742*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5743*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5744*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5745*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5746*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5747*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5748*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5749*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5750*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5751*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5752*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5753*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5754*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5755*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5756*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5757*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5758*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5759*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
5760*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5761*4bdc9457SAndroid Build Coastguard Worker }
5762*4bdc9457SAndroid Build Coastguard Worker }
5763*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_output_stride)5764*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_output_stride) {
5765*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5766*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5767*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5768*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5769*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5770*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5771*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5772*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5773*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5774*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5775*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5776*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5777*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5778*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5779*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5780*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5781*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5782*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
5783*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5784*4bdc9457SAndroid Build Coastguard Worker }
5785*4bdc9457SAndroid Build Coastguard Worker }
5786*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_qmin)5787*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_qmin) {
5788*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5789*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5790*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5791*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5792*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5793*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5794*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5795*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5796*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5797*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5798*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5799*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5800*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5801*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5802*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5803*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5804*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5805*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5806*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5807*4bdc9457SAndroid Build Coastguard Worker }
5808*4bdc9457SAndroid Build Coastguard Worker }
5809*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_pool_with_qmax)5810*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_pool_with_qmax) {
5811*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5812*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5813*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5814*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5815*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5816*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5817*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5818*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5819*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5820*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5821*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5822*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5823*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5824*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5825*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5826*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5827*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5828*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5829*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5830*4bdc9457SAndroid Build Coastguard Worker }
5831*4bdc9457SAndroid Build Coastguard Worker }
5832*4bdc9457SAndroid Build Coastguard Worker
5833*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, multipass, batched ****************************/
5834*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool)5835*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool) {
5836*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5837*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.avgpool.primary_tile * 2);
5838*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5839*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5840*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5841*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5842*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5843*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5844*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5845*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5846*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5847*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5848*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5849*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5850*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5851*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5852*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5853*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5854*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5855*4bdc9457SAndroid Build Coastguard Worker }
5856*4bdc9457SAndroid Build Coastguard Worker }
5857*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_stride)5858*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_stride) {
5859*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5860*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5861*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5862*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_width = 1; stride_width <= 2; stride_width++) {
5863*4bdc9457SAndroid Build Coastguard Worker for (size_t stride_height = 1; stride_height <= 2; stride_height++) {
5864*4bdc9457SAndroid Build Coastguard Worker if (stride_width == 1 && stride_height == 1) {
5865*4bdc9457SAndroid Build Coastguard Worker continue;
5866*4bdc9457SAndroid Build Coastguard Worker }
5867*4bdc9457SAndroid Build Coastguard Worker
5868*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5869*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5870*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5871*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5872*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5873*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5874*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5875*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5876*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5877*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5878*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5879*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5880*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5881*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5882*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5883*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5884*4bdc9457SAndroid Build Coastguard Worker .stride_height(stride_height)
5885*4bdc9457SAndroid Build Coastguard Worker .stride_width(stride_width)
5886*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5887*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5888*4bdc9457SAndroid Build Coastguard Worker }
5889*4bdc9457SAndroid Build Coastguard Worker }
5890*4bdc9457SAndroid Build Coastguard Worker }
5891*4bdc9457SAndroid Build Coastguard Worker }
5892*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_width_padding)5893*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_width_padding) {
5894*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5895*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5896*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5897*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5898*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 0; padding_left <= 1; padding_left++) {
5899*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 0; padding_right <= 1; padding_right++) {
5900*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5901*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5902*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5903*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5904*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5905*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5906*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5907*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5908*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5909*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5910*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5911*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5912*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5913*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5914*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5915*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
5916*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
5917*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5918*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5919*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5920*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5921*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5922*4bdc9457SAndroid Build Coastguard Worker }
5923*4bdc9457SAndroid Build Coastguard Worker }
5924*4bdc9457SAndroid Build Coastguard Worker }
5925*4bdc9457SAndroid Build Coastguard Worker }
5926*4bdc9457SAndroid Build Coastguard Worker }
5927*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_height_padding)5928*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_height_padding) {
5929*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5930*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5931*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5932*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5933*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
5934*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 0; padding_bottom <= 1; padding_bottom++) {
5935*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5936*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5937*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5938*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5939*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5940*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5941*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5942*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5943*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5944*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5945*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5946*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5947*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5948*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
5949*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5950*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
5951*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
5952*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5953*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
5954*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5955*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5956*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5957*4bdc9457SAndroid Build Coastguard Worker }
5958*4bdc9457SAndroid Build Coastguard Worker }
5959*4bdc9457SAndroid Build Coastguard Worker }
5960*4bdc9457SAndroid Build Coastguard Worker }
5961*4bdc9457SAndroid Build Coastguard Worker }
5962*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_tf_same_padding)5963*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_tf_same_padding) {
5964*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
5965*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
5966*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
5967*4bdc9457SAndroid Build Coastguard Worker for (size_t stride = 1; stride <= 2; stride++) {
5968*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.first + 3; input_height <= pooling_size.first + 4; input_height++) {
5969*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5970*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5971*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5972*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
5973*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5974*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5975*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5976*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5977*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5978*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5979*4bdc9457SAndroid Build Coastguard Worker }
5980*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.second + 2; input_width <= pooling_size.second + 3; input_width++) {
5981*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5982*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5983*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
5984*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
5985*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5986*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
5987*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
5988*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
5989*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
5990*4bdc9457SAndroid Build Coastguard Worker .TestF32();
5991*4bdc9457SAndroid Build Coastguard Worker }
5992*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = pooling_size.second + 3; input_height <= pooling_size.second + 4; input_height++) {
5993*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
5994*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
5995*4bdc9457SAndroid Build Coastguard Worker .input_height(input_height)
5996*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
5997*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5998*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
5999*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6000*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
6001*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6002*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6003*4bdc9457SAndroid Build Coastguard Worker }
6004*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = pooling_size.first + 2; input_width <= pooling_size.first + 3; input_width++) {
6005*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6006*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6007*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
6008*4bdc9457SAndroid Build Coastguard Worker .input_width(input_width)
6009*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
6010*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6011*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6012*4bdc9457SAndroid Build Coastguard Worker .stride(stride)
6013*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6014*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6015*4bdc9457SAndroid Build Coastguard Worker }
6016*4bdc9457SAndroid Build Coastguard Worker }
6017*4bdc9457SAndroid Build Coastguard Worker }
6018*4bdc9457SAndroid Build Coastguard Worker }
6019*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_input_stride)6020*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_input_stride) {
6021*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6022*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6023*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6024*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6025*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6026*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
6027*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
6028*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6029*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6030*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6031*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6032*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6033*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6034*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6035*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
6036*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
6037*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6038*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6039*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6040*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6041*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6042*4bdc9457SAndroid Build Coastguard Worker }
6043*4bdc9457SAndroid Build Coastguard Worker }
6044*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_output_stride)6045*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_output_stride) {
6046*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6047*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6048*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6049*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6050*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6051*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
6052*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
6053*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6054*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6055*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6056*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6057*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6058*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6059*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6060*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
6061*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
6062*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6063*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6064*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6065*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6066*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6067*4bdc9457SAndroid Build Coastguard Worker }
6068*4bdc9457SAndroid Build Coastguard Worker }
6069*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_qmin)6070*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_qmin) {
6071*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6072*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6073*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6074*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6075*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6076*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
6077*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
6078*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6079*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6080*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6081*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6082*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6083*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6084*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6085*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
6086*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
6087*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6088*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6089*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6090*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6091*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6092*4bdc9457SAndroid Build Coastguard Worker }
6093*4bdc9457SAndroid Build Coastguard Worker }
6094*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_pool_with_qmax)6095*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_pool_with_qmax) {
6096*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6097*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6098*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6099*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6100*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6101*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first + 3)
6102*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second + 2)
6103*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6104*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6105*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6106*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6107*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6108*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6109*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6110*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second + 3)
6111*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first + 2)
6112*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6113*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6114*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6115*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6116*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6117*4bdc9457SAndroid Build Coastguard Worker }
6118*4bdc9457SAndroid Build Coastguard Worker }
6119*4bdc9457SAndroid Build Coastguard Worker
6120*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass ****************************/
6121*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image)6122*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image) {
6123*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6124*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6125*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6126*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6127*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6128*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6129*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6130*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6131*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6132*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6133*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6134*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6135*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6136*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6137*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6138*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6139*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6140*4bdc9457SAndroid Build Coastguard Worker }
6141*4bdc9457SAndroid Build Coastguard Worker }
6142*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_width_padding)6143*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_width_padding) {
6144*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6145*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6146*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6147*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
6148*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6149*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6150*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
6151*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
6152*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6153*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6154*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6155*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6156*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6157*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6158*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
6159*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
6160*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6161*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6162*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6163*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6164*4bdc9457SAndroid Build Coastguard Worker
6165*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
6166*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6167*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6168*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
6169*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
6170*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6171*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6172*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6173*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6174*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6175*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6176*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
6177*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
6178*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6179*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6180*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6181*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6182*4bdc9457SAndroid Build Coastguard Worker }
6183*4bdc9457SAndroid Build Coastguard Worker }
6184*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_height_padding)6185*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_height_padding) {
6186*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6187*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6188*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6189*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
6190*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6191*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
6192*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6193*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
6194*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6195*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6196*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6197*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6198*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6199*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
6200*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6201*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
6202*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6203*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6204*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6205*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6206*4bdc9457SAndroid Build Coastguard Worker
6207*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
6208*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6209*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
6210*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6211*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
6212*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6213*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6214*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6215*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6216*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6217*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
6218*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6219*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
6220*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6221*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6222*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6223*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6224*4bdc9457SAndroid Build Coastguard Worker }
6225*4bdc9457SAndroid Build Coastguard Worker }
6226*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_input_stride)6227*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_input_stride) {
6228*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6229*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6230*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6231*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6232*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6233*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6234*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6235*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6236*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6237*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6238*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6239*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6240*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6241*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6242*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6243*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6244*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6245*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6246*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6247*4bdc9457SAndroid Build Coastguard Worker }
6248*4bdc9457SAndroid Build Coastguard Worker }
6249*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_output_stride)6250*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_output_stride) {
6251*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6252*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6253*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6254*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6255*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6256*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6257*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6258*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6259*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6260*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6261*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6262*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6263*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6264*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6265*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6266*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6267*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6268*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6269*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6270*4bdc9457SAndroid Build Coastguard Worker }
6271*4bdc9457SAndroid Build Coastguard Worker }
6272*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_qmin)6273*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_qmin) {
6274*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6275*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6276*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6277*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6278*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6279*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6280*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6281*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6282*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6283*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6284*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6285*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6286*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6287*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6288*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6289*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6290*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6291*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6292*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6293*4bdc9457SAndroid Build Coastguard Worker }
6294*4bdc9457SAndroid Build Coastguard Worker }
6295*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,small_image_with_qmax)6296*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, small_image_with_qmax) {
6297*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6298*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6299*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6300*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6301*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6302*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6303*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6304*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6305*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6306*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6307*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6308*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6309*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6310*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6311*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6312*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6313*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6314*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6315*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6316*4bdc9457SAndroid Build Coastguard Worker }
6317*4bdc9457SAndroid Build Coastguard Worker }
6318*4bdc9457SAndroid Build Coastguard Worker
6319*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, unipass, batched ****************************/
6320*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image)6321*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image) {
6322*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6323*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6324*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6325*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6326*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6327*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6328*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6329*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6330*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6331*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6332*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6333*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6334*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6335*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6336*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6337*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6338*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6339*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6340*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6341*4bdc9457SAndroid Build Coastguard Worker }
6342*4bdc9457SAndroid Build Coastguard Worker }
6343*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_width_padding)6344*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_width_padding) {
6345*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6346*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6347*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6348*4bdc9457SAndroid Build Coastguard Worker /* With left padding */
6349*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6350*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6351*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6352*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
6353*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
6354*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6355*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6356*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6357*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6358*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6359*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6360*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6361*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
6362*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
6363*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6364*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6365*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6366*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6367*4bdc9457SAndroid Build Coastguard Worker
6368*4bdc9457SAndroid Build Coastguard Worker /* With right padding */
6369*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6370*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6371*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6372*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - 1)
6373*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
6374*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6375*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6376*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6377*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6378*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6379*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6380*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6381*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - 1)
6382*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
6383*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6384*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6385*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6386*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6387*4bdc9457SAndroid Build Coastguard Worker }
6388*4bdc9457SAndroid Build Coastguard Worker }
6389*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_height_padding)6390*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_height_padding) {
6391*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6392*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6393*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6394*4bdc9457SAndroid Build Coastguard Worker /* With top padding */
6395*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6396*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6397*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
6398*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6399*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
6400*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6401*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6402*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6403*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6404*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6405*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6406*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
6407*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6408*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
6409*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6410*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6411*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6412*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6413*4bdc9457SAndroid Build Coastguard Worker
6414*4bdc9457SAndroid Build Coastguard Worker /* With bottom padding */
6415*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6416*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6417*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - 1)
6418*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6419*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
6420*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6421*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6422*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6423*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6424*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6425*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6426*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - 1)
6427*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6428*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
6429*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6430*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6431*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6432*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6433*4bdc9457SAndroid Build Coastguard Worker }
6434*4bdc9457SAndroid Build Coastguard Worker }
6435*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_input_stride)6436*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_input_stride) {
6437*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6438*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6439*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6440*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6441*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6442*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6443*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6444*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6445*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6446*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6447*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6448*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6449*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6450*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6451*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6452*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6453*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6454*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6455*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6456*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6457*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6458*4bdc9457SAndroid Build Coastguard Worker }
6459*4bdc9457SAndroid Build Coastguard Worker }
6460*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_output_stride)6461*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_output_stride) {
6462*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6463*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6464*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6465*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6466*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6467*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6468*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6469*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6470*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6471*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6472*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6473*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6474*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6475*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6476*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6477*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6478*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6479*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6480*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6481*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6482*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6483*4bdc9457SAndroid Build Coastguard Worker }
6484*4bdc9457SAndroid Build Coastguard Worker }
6485*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_qmin)6486*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_qmin) {
6487*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6488*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6489*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6490*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6491*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6492*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6493*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6494*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6495*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6496*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6497*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6498*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6499*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6500*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6501*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6502*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6503*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6504*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6505*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6506*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6507*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6508*4bdc9457SAndroid Build Coastguard Worker }
6509*4bdc9457SAndroid Build Coastguard Worker }
6510*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_small_image_with_qmax)6511*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_small_image_with_qmax) {
6512*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6513*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = SmallPoolSize(xnn_params.f32.gavgpool.row_tile);
6514*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6515*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6516*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6517*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6518*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6519*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6520*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6521*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6522*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6523*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6524*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6525*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6526*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6527*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6528*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6529*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6530*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6531*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6532*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6533*4bdc9457SAndroid Build Coastguard Worker }
6534*4bdc9457SAndroid Build Coastguard Worker }
6535*4bdc9457SAndroid Build Coastguard Worker
6536*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass ****************************/
6537*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image)6538*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image) {
6539*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6540*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6541*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6542*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6543*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6544*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6545*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6546*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6547*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6548*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6549*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6550*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6551*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6552*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6553*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6554*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6555*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6556*4bdc9457SAndroid Build Coastguard Worker }
6557*4bdc9457SAndroid Build Coastguard Worker }
6558*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_width_padding)6559*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_width_padding) {
6560*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6561*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6562*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6563*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
6564*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6565*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6566*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
6567*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
6568*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6569*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6570*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6571*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6572*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6573*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6574*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
6575*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
6576*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6577*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6578*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6579*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6580*4bdc9457SAndroid Build Coastguard Worker }
6581*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
6582*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6583*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6584*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
6585*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
6586*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6587*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6588*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6589*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6590*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6591*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6592*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
6593*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
6594*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6595*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6596*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6597*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6598*4bdc9457SAndroid Build Coastguard Worker }
6599*4bdc9457SAndroid Build Coastguard Worker }
6600*4bdc9457SAndroid Build Coastguard Worker }
6601*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_height_padding)6602*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_height_padding) {
6603*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6604*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6605*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6606*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 1; padding_top <= 2; padding_top++) {
6607*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6608*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
6609*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6610*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
6611*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6612*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6613*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6614*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6615*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6616*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
6617*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6618*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
6619*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6620*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6621*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6622*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6623*4bdc9457SAndroid Build Coastguard Worker }
6624*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 1; padding_bottom <= 2; padding_bottom++) {
6625*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6626*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
6627*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6628*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
6629*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6630*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6631*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6632*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6633*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6634*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
6635*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6636*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
6637*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6638*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6639*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6640*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6641*4bdc9457SAndroid Build Coastguard Worker }
6642*4bdc9457SAndroid Build Coastguard Worker }
6643*4bdc9457SAndroid Build Coastguard Worker }
6644*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_input_stride)6645*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_input_stride) {
6646*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6647*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6648*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6649*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6650*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6651*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6652*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6653*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6654*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6655*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6656*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6657*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6658*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6659*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6660*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6661*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6662*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6663*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6664*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6665*4bdc9457SAndroid Build Coastguard Worker }
6666*4bdc9457SAndroid Build Coastguard Worker }
6667*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_output_stride)6668*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_output_stride) {
6669*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6670*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6671*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6672*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6673*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6674*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6675*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6676*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6677*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6678*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6679*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6680*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6681*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6682*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6683*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6684*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6685*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6686*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6687*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6688*4bdc9457SAndroid Build Coastguard Worker }
6689*4bdc9457SAndroid Build Coastguard Worker }
6690*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_qmin)6691*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_qmin) {
6692*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6693*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6694*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6695*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6696*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6697*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6698*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6699*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6700*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6701*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6702*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6703*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6704*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6705*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6706*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6707*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6708*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6709*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6710*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6711*4bdc9457SAndroid Build Coastguard Worker }
6712*4bdc9457SAndroid Build Coastguard Worker }
6713*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,large_image_with_qmax)6714*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, large_image_with_qmax) {
6715*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6716*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6717*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6718*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6719*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6720*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6721*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6722*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6723*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6724*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6725*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6726*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6727*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6728*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6729*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6730*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6731*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6732*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6733*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6734*4bdc9457SAndroid Build Coastguard Worker }
6735*4bdc9457SAndroid Build Coastguard Worker }
6736*4bdc9457SAndroid Build Coastguard Worker
6737*4bdc9457SAndroid Build Coastguard Worker /**************************** GAVGPOOL path, multipass, batched ****************************/
6738*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image)6739*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image) {
6740*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6741*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6742*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6743*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6744*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6745*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6746*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6747*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6748*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6749*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6750*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6751*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6752*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6753*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6754*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6755*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6756*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6757*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6758*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6759*4bdc9457SAndroid Build Coastguard Worker }
6760*4bdc9457SAndroid Build Coastguard Worker }
6761*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_width_padding)6762*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_width_padding) {
6763*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6764*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6765*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6766*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_left = 1; padding_left <= 2; padding_left++) {
6767*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6768*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6769*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6770*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_left)
6771*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
6772*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6773*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6774*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6775*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6776*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6777*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6778*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6779*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_left)
6780*4bdc9457SAndroid Build Coastguard Worker .padding_left(padding_left)
6781*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6782*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6783*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6784*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6785*4bdc9457SAndroid Build Coastguard Worker }
6786*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_right = 1; padding_right <= 2; padding_right++) {
6787*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6788*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6789*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6790*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second - padding_right)
6791*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
6792*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6793*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6794*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6795*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6796*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6797*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6798*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6799*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first - padding_right)
6800*4bdc9457SAndroid Build Coastguard Worker .padding_right(padding_right)
6801*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6802*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6803*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6804*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6805*4bdc9457SAndroid Build Coastguard Worker }
6806*4bdc9457SAndroid Build Coastguard Worker }
6807*4bdc9457SAndroid Build Coastguard Worker }
6808*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_height_padding)6809*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_height_padding) {
6810*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6811*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6812*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6813*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_top = 0; padding_top <= 1; padding_top++) {
6814*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6815*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6816*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_top)
6817*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6818*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
6819*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6820*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6821*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6822*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6823*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6824*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6825*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_top)
6826*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6827*4bdc9457SAndroid Build Coastguard Worker .padding_top(padding_top)
6828*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6829*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6830*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6831*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6832*4bdc9457SAndroid Build Coastguard Worker }
6833*4bdc9457SAndroid Build Coastguard Worker for (size_t padding_bottom = 1; padding_bottom <= 2; padding_bottom++) {
6834*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6835*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6836*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first - padding_bottom)
6837*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6838*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
6839*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6840*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6841*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6842*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6843*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6844*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6845*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second - padding_bottom)
6846*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6847*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(padding_bottom)
6848*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6849*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6850*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6851*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6852*4bdc9457SAndroid Build Coastguard Worker }
6853*4bdc9457SAndroid Build Coastguard Worker }
6854*4bdc9457SAndroid Build Coastguard Worker }
6855*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_input_stride)6856*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_input_stride) {
6857*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6858*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6859*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6860*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6861*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6862*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6863*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6864*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6865*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6866*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6867*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6868*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6869*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6870*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6871*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6872*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6873*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6874*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6875*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6876*4bdc9457SAndroid Build Coastguard Worker .input_pixel_stride(2 * channels + 3)
6877*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6878*4bdc9457SAndroid Build Coastguard Worker }
6879*4bdc9457SAndroid Build Coastguard Worker }
6880*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_output_stride)6881*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_output_stride) {
6882*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6883*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6884*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6885*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6886*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6887*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6888*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6889*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6890*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6891*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6892*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6893*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6894*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6895*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6896*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6897*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6898*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6899*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6900*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6901*4bdc9457SAndroid Build Coastguard Worker .output_pixel_stride(2 * channels + 3)
6902*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6903*4bdc9457SAndroid Build Coastguard Worker }
6904*4bdc9457SAndroid Build Coastguard Worker }
6905*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_qmin)6906*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_qmin) {
6907*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6908*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6909*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6910*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6911*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6912*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6913*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6914*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6915*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6916*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6917*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6918*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6919*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6920*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6921*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6922*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6923*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6924*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6925*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6926*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6927*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6928*4bdc9457SAndroid Build Coastguard Worker }
6929*4bdc9457SAndroid Build Coastguard Worker }
6930*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,batched_large_image_with_qmax)6931*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, batched_large_image_with_qmax) {
6932*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6933*4bdc9457SAndroid Build Coastguard Worker const std::pair<size_t, size_t> pooling_size = LargePoolSize(xnn_params.f32.gavgpool.row_tile * 2);
6934*4bdc9457SAndroid Build Coastguard Worker for (size_t channels = 1; channels <= 100; channels += 15) {
6935*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6936*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6937*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.first)
6938*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.second)
6939*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.first)
6940*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.second)
6941*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6942*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6943*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6944*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6945*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6946*4bdc9457SAndroid Build Coastguard Worker .input_height(pooling_size.second)
6947*4bdc9457SAndroid Build Coastguard Worker .input_width(pooling_size.first)
6948*4bdc9457SAndroid Build Coastguard Worker .pooling_height(pooling_size.second)
6949*4bdc9457SAndroid Build Coastguard Worker .pooling_width(pooling_size.first)
6950*4bdc9457SAndroid Build Coastguard Worker .channels(channels)
6951*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6952*4bdc9457SAndroid Build Coastguard Worker .TestF32();
6953*4bdc9457SAndroid Build Coastguard Worker }
6954*4bdc9457SAndroid Build Coastguard Worker }
6955*4bdc9457SAndroid Build Coastguard Worker
6956*4bdc9457SAndroid Build Coastguard Worker /**************************** AVGPOOL path, setup ****************************/
6957*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_increasing_batch)6958*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_increasing_batch) {
6959*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6960*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6961*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6962*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
6963*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6964*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6965*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
6966*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
6967*4bdc9457SAndroid Build Coastguard Worker .channels(24)
6968*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
6969*4bdc9457SAndroid Build Coastguard Worker }
6970*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_decreasing_batch)6971*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_decreasing_batch) {
6972*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6973*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6974*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
6975*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(2)
6976*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6977*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6978*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
6979*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
6980*4bdc9457SAndroid Build Coastguard Worker .channels(24)
6981*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
6982*4bdc9457SAndroid Build Coastguard Worker }
6983*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_changing_height)6984*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_changing_height) {
6985*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6986*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6987*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6988*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6989*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6990*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
6991*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
6992*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
6993*4bdc9457SAndroid Build Coastguard Worker .channels(24)
6994*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
6995*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
6996*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
6997*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6998*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6999*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
7000*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7001*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7002*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7003*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7004*4bdc9457SAndroid Build Coastguard Worker }
7005*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_changing_width)7006*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_changing_width) {
7007*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
7008*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
7009*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
7010*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
7011*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
7012*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
7013*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7014*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7015*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7016*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7017*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
7018*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
7019*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
7020*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
7021*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
7022*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7023*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7024*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7025*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7026*4bdc9457SAndroid Build Coastguard Worker }
7027*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_swap_height_and_width)7028*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_swap_height_and_width) {
7029*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
7030*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
7031*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
7032*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
7033*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
7034*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
7035*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
7036*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7037*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7038*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7039*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7040*4bdc9457SAndroid Build Coastguard Worker }
7041*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_local_to_global)7042*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_local_to_global) {
7043*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
7044*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
7045*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
7046*4bdc9457SAndroid Build Coastguard Worker .input_height(6)
7047*4bdc9457SAndroid Build Coastguard Worker .input_width(5)
7048*4bdc9457SAndroid Build Coastguard Worker .next_input_height(5)
7049*4bdc9457SAndroid Build Coastguard Worker .next_input_width(3)
7050*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7051*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7052*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7053*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7054*4bdc9457SAndroid Build Coastguard Worker }
7055*4bdc9457SAndroid Build Coastguard Worker
TEST(AVERAGE_POOLING_NHWC_F32,setup_global_to_local)7056*4bdc9457SAndroid Build Coastguard Worker TEST(AVERAGE_POOLING_NHWC_F32, setup_global_to_local) {
7057*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
7058*4bdc9457SAndroid Build Coastguard Worker AveragePoolingOperatorTester()
7059*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
7060*4bdc9457SAndroid Build Coastguard Worker .input_height(5)
7061*4bdc9457SAndroid Build Coastguard Worker .input_width(3)
7062*4bdc9457SAndroid Build Coastguard Worker .next_input_height(6)
7063*4bdc9457SAndroid Build Coastguard Worker .next_input_width(5)
7064*4bdc9457SAndroid Build Coastguard Worker .pooling_height(5)
7065*4bdc9457SAndroid Build Coastguard Worker .pooling_width(3)
7066*4bdc9457SAndroid Build Coastguard Worker .channels(24)
7067*4bdc9457SAndroid Build Coastguard Worker .TestSetupF32();
7068*4bdc9457SAndroid Build Coastguard Worker }
7069