xref: /aosp_15_r20/external/XNNPACK/test/convolution-nchw.cc (revision 4bdc94577ba0e567308109d787f7fec7b531ce36)
1*4bdc9457SAndroid Build Coastguard Worker // Copyright 2019 Google LLC
2*4bdc9457SAndroid Build Coastguard Worker //
3*4bdc9457SAndroid Build Coastguard Worker // This source code is licensed under the BSD-style license found in the
4*4bdc9457SAndroid Build Coastguard Worker // LICENSE file in the root directory of this source tree.
5*4bdc9457SAndroid Build Coastguard Worker 
6*4bdc9457SAndroid Build Coastguard Worker #include <gtest/gtest.h>
7*4bdc9457SAndroid Build Coastguard Worker 
8*4bdc9457SAndroid Build Coastguard Worker #include "convolution-operator-tester.h"
9*4bdc9457SAndroid Build Coastguard Worker 
10*4bdc9457SAndroid Build Coastguard Worker 
11*4bdc9457SAndroid Build Coastguard Worker /**************************** SPMM path ****************************/
12*4bdc9457SAndroid Build Coastguard Worker 
13*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1) {
14*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
15*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
16*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
17*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
18*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
19*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
20*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
21*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
22*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
23*4bdc9457SAndroid Build Coastguard Worker }
24*4bdc9457SAndroid Build Coastguard Worker 
25*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_zero_weights) {
26*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
27*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
28*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
29*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
30*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
31*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
32*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
33*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
34*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
35*4bdc9457SAndroid Build Coastguard Worker }
36*4bdc9457SAndroid Build Coastguard Worker 
37*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_varying_input_height) {
38*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
39*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
40*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
41*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
42*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
43*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
44*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
45*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
46*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
47*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
48*4bdc9457SAndroid Build Coastguard Worker   }
49*4bdc9457SAndroid Build Coastguard Worker }
50*4bdc9457SAndroid Build Coastguard Worker 
51*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_varying_input_width) {
52*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
53*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
54*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
55*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
56*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
57*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
58*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
59*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
60*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
61*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
62*4bdc9457SAndroid Build Coastguard Worker   }
63*4bdc9457SAndroid Build Coastguard Worker }
64*4bdc9457SAndroid Build Coastguard Worker 
65*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_varying_input_channels) {
66*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
67*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_channels = 1; input_channels <= 16; input_channels *= 4) {
68*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
69*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
70*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
71*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(input_channels)
72*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
73*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
74*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
75*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
76*4bdc9457SAndroid Build Coastguard Worker   }
77*4bdc9457SAndroid Build Coastguard Worker }
78*4bdc9457SAndroid Build Coastguard Worker 
79*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_varying_output_channels) {
80*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
81*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_channels = 1; output_channels < 19; output_channels *= 2) {
82*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
83*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
84*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
85*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
86*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(output_channels)
87*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
88*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
89*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
90*4bdc9457SAndroid Build Coastguard Worker   }
91*4bdc9457SAndroid Build Coastguard Worker }
92*4bdc9457SAndroid Build Coastguard Worker 
93*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_with_qmin) {
94*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
95*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
96*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
97*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
98*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
99*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
100*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
101*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
102*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
103*4bdc9457SAndroid Build Coastguard Worker }
104*4bdc9457SAndroid Build Coastguard Worker 
105*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_with_qmax) {
106*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
107*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
108*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
109*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
110*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
111*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
112*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
113*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
114*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
115*4bdc9457SAndroid Build Coastguard Worker }
116*4bdc9457SAndroid Build Coastguard Worker 
117*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, 1x1_without_bias) {
118*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
119*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
120*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
121*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
122*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
123*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
124*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
125*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
126*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
127*4bdc9457SAndroid Build Coastguard Worker }
128*4bdc9457SAndroid Build Coastguard Worker 
129*4bdc9457SAndroid Build Coastguard Worker // Weights cache is not supported for SPMM microkernel, add a test here, but skip the assertions.
TEST(CONVOLUTION_NCHW_F32,weights_cache_1x1)130*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, weights_cache_1x1) {
131*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
132*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
133*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
134*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
135*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
136*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
137*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
138*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
139*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
140*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
141*4bdc9457SAndroid Build Coastguard Worker }
142*4bdc9457SAndroid Build Coastguard Worker 
143*4bdc9457SAndroid Build Coastguard Worker /**************************** SPMM path, batched ****************************/
144*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1)145*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1) {
146*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
147*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
148*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
149*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
150*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
151*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
152*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
153*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
154*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
155*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
156*4bdc9457SAndroid Build Coastguard Worker }
157*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_zero_weights)158*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_zero_weights) {
159*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
160*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
161*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
162*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
163*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
164*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
165*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
166*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
167*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
168*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
169*4bdc9457SAndroid Build Coastguard Worker }
170*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_varying_input_height)171*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_varying_input_height) {
172*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
173*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
174*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
175*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
176*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
177*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
178*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
179*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
180*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
181*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
182*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
183*4bdc9457SAndroid Build Coastguard Worker   }
184*4bdc9457SAndroid Build Coastguard Worker }
185*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_varying_input_width)186*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_varying_input_width) {
187*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
188*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
189*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
190*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
191*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
192*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
193*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
194*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
195*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
196*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
197*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
198*4bdc9457SAndroid Build Coastguard Worker   }
199*4bdc9457SAndroid Build Coastguard Worker }
200*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_varying_input_channels)201*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_varying_input_channels) {
202*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
203*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_channels = 1; input_channels <= 16; input_channels *= 4) {
204*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
205*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
206*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
207*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
208*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(input_channels)
209*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
210*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
211*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
212*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
213*4bdc9457SAndroid Build Coastguard Worker   }
214*4bdc9457SAndroid Build Coastguard Worker }
215*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_varying_output_channels)216*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_varying_output_channels) {
217*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
218*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_channels = 1; output_channels < 19; output_channels *= 2) {
219*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
220*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
221*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
222*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(1, 1)
223*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(23)
224*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(output_channels)
225*4bdc9457SAndroid Build Coastguard Worker       .sparsity(0.5f)
226*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
227*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
228*4bdc9457SAndroid Build Coastguard Worker   }
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_with_input_stride)231*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_with_input_stride) {
232*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
233*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
234*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
235*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
236*4bdc9457SAndroid Build Coastguard Worker     .input_channel_stride(25)
237*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
238*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
239*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
240*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
241*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
242*4bdc9457SAndroid Build Coastguard Worker }
243*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_with_output_stride)244*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_with_output_stride) {
245*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
246*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
247*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
248*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
249*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(21)
250*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
251*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
252*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
253*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
254*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
255*4bdc9457SAndroid Build Coastguard Worker }
256*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_with_qmin)257*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_with_qmin) {
258*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
259*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
260*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
261*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
262*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
263*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
264*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
265*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
266*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
267*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
268*4bdc9457SAndroid Build Coastguard Worker }
269*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_with_qmax)270*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_with_qmax) {
271*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
272*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
273*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
274*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
275*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
276*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
277*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
278*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
279*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
280*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
281*4bdc9457SAndroid Build Coastguard Worker }
282*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_1x1_without_bias)283*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_1x1_without_bias) {
284*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
285*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
286*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
287*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
288*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(1, 1)
289*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(23)
290*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
291*4bdc9457SAndroid Build Coastguard Worker     .sparsity(0.5f)
292*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
293*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
294*4bdc9457SAndroid Build Coastguard Worker }
295*4bdc9457SAndroid Build Coastguard Worker 
296*4bdc9457SAndroid Build Coastguard Worker /**************************** DConv 3x3c3s2 HWC->CHW path ****************************/
297*4bdc9457SAndroid Build Coastguard Worker 
298*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2) {
299*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
300*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
301*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
302*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
303*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
304*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
305*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
306*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
307*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
308*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
309*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
310*4bdc9457SAndroid Build Coastguard Worker }
311*4bdc9457SAndroid Build Coastguard Worker 
312*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_varying_input_height) {
313*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
314*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
315*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
316*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
317*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
318*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
319*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
320*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
321*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
322*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
323*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
324*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
325*4bdc9457SAndroid Build Coastguard Worker   }
326*4bdc9457SAndroid Build Coastguard Worker }
327*4bdc9457SAndroid Build Coastguard Worker 
328*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_varying_input_width) {
329*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
330*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
331*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
332*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
333*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
334*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
335*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
336*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
337*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
338*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
339*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
340*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
341*4bdc9457SAndroid Build Coastguard Worker   }
342*4bdc9457SAndroid Build Coastguard Worker }
343*4bdc9457SAndroid Build Coastguard Worker 
344*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_varying_output_channels) {
345*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
346*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_channels = 1; output_channels < 19; output_channels *= 2) {
347*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
348*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
349*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
350*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
351*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
352*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
353*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(output_channels)
354*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
355*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
356*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
357*4bdc9457SAndroid Build Coastguard Worker   }
358*4bdc9457SAndroid Build Coastguard Worker }
359*4bdc9457SAndroid Build Coastguard Worker 
360*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_with_qmin) {
361*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
362*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
363*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
364*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
365*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
366*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
367*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
368*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
369*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
370*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
371*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
372*4bdc9457SAndroid Build Coastguard Worker }
373*4bdc9457SAndroid Build Coastguard Worker 
374*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_with_qmax) {
375*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
376*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
377*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
378*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
379*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
380*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
381*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
382*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
383*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
384*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
385*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
386*4bdc9457SAndroid Build Coastguard Worker }
387*4bdc9457SAndroid Build Coastguard Worker 
388*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, 3x3c3s2_without_bias) {
389*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
390*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
391*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
392*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
393*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
394*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
395*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
396*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
397*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
398*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
399*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
400*4bdc9457SAndroid Build Coastguard Worker }
401*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,weights_cache_3x3c3s2)402*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, weights_cache_3x3c3s2) {
403*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
404*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
405*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
406*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
407*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
408*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
409*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
410*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
411*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
412*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
413*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
414*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
415*4bdc9457SAndroid Build Coastguard Worker }
416*4bdc9457SAndroid Build Coastguard Worker 
417*4bdc9457SAndroid Build Coastguard Worker /**************************** DConv 3x3c3s2 HWC->CHW path, batched ****************************/
418*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2)419*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2) {
420*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
421*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
422*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
423*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
424*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
425*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
426*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
427*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
428*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
429*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
430*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
431*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
432*4bdc9457SAndroid Build Coastguard Worker }
433*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_varying_input_height)434*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_varying_input_height) {
435*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
436*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
437*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
438*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
439*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
440*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
441*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
442*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
443*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
444*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
445*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
446*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
447*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
448*4bdc9457SAndroid Build Coastguard Worker   }
449*4bdc9457SAndroid Build Coastguard Worker }
450*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_varying_input_width)451*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_varying_input_width) {
452*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
453*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
454*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
455*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
456*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
457*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
458*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
459*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
460*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
461*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(19)
462*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
463*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
464*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
465*4bdc9457SAndroid Build Coastguard Worker   }
466*4bdc9457SAndroid Build Coastguard Worker }
467*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_varying_output_channels)468*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_varying_output_channels) {
469*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
470*4bdc9457SAndroid Build Coastguard Worker   for (size_t output_channels = 1; output_channels < 19; output_channels *= 2) {
471*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
472*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
473*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
474*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
475*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
476*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
477*4bdc9457SAndroid Build Coastguard Worker       .group_input_channels(3)
478*4bdc9457SAndroid Build Coastguard Worker       .group_output_channels(output_channels)
479*4bdc9457SAndroid Build Coastguard Worker       .force_nhwc_input(true)
480*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
481*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
482*4bdc9457SAndroid Build Coastguard Worker   }
483*4bdc9457SAndroid Build Coastguard Worker }
484*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_with_output_stride)485*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_with_output_stride) {
486*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
487*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
488*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
489*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
490*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
491*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
492*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(21)
493*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
494*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
495*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
496*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
497*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
498*4bdc9457SAndroid Build Coastguard Worker }
499*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_with_qmin)500*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_with_qmin) {
501*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
502*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
503*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
504*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
505*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
506*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
507*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
508*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
509*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
510*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
511*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
512*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
513*4bdc9457SAndroid Build Coastguard Worker }
514*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_with_qmax)515*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_with_qmax) {
516*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
517*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
518*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
519*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
520*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
521*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
522*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
523*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
524*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
525*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
526*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
527*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
528*4bdc9457SAndroid Build Coastguard Worker }
529*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,batched_3x3c3s2_without_bias)530*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, batched_3x3c3s2_without_bias) {
531*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
532*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
533*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
534*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
535*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
536*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
537*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
538*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
539*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
540*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
541*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
542*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
543*4bdc9457SAndroid Build Coastguard Worker }
544*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NHWC2NCHW_OP_F32,weights_cache_batched_3x3c3s2)545*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC2NCHW_OP_F32, weights_cache_batched_3x3c3s2) {
546*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
547*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
548*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
549*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
550*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
551*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
552*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
553*4bdc9457SAndroid Build Coastguard Worker     .group_input_channels(3)
554*4bdc9457SAndroid Build Coastguard Worker     .group_output_channels(19)
555*4bdc9457SAndroid Build Coastguard Worker     .force_nhwc_input(true)
556*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
557*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
558*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
559*4bdc9457SAndroid Build Coastguard Worker }
560*4bdc9457SAndroid Build Coastguard Worker 
561*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 path ****************************/
562*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3)563*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3) {
564*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
565*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
566*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
567*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
568*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
569*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
570*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
571*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
572*4bdc9457SAndroid Build Coastguard Worker }
573*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_zero_weights)574*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_zero_weights) {
575*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
576*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
577*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
578*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
579*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
580*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
581*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
582*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
583*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_varying_input_height)586*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_varying_input_height) {
587*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
588*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
589*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
590*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
591*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
592*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
593*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
594*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
595*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
596*4bdc9457SAndroid Build Coastguard Worker   }
597*4bdc9457SAndroid Build Coastguard Worker }
598*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_varying_input_width)599*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_varying_input_width) {
600*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
601*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
602*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
603*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
604*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
605*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
606*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
607*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
608*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
609*4bdc9457SAndroid Build Coastguard Worker   }
610*4bdc9457SAndroid Build Coastguard Worker }
611*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_varying_channels)612*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_varying_channels) {
613*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
614*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
615*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
616*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
617*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
618*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
619*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
620*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
621*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
622*4bdc9457SAndroid Build Coastguard Worker   }
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_with_qmin)625*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_with_qmin) {
626*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
627*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
628*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
629*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
630*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
631*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
632*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
633*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
634*4bdc9457SAndroid Build Coastguard Worker }
635*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_with_qmax)636*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_with_qmax) {
637*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
638*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
639*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
640*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
641*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
642*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
643*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
644*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
645*4bdc9457SAndroid Build Coastguard Worker }
646*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3_without_bias)647*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3_without_bias) {
648*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
649*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
650*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
651*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
652*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
653*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
654*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
655*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
656*4bdc9457SAndroid Build Coastguard Worker }
657*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,weights_cache_depthwise_3x3)658*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, weights_cache_depthwise_3x3) {
659*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
660*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
661*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
662*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
663*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
664*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
665*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
666*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
667*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
668*4bdc9457SAndroid Build Coastguard Worker }
669*4bdc9457SAndroid Build Coastguard Worker 
670*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 path, batched ****************************/
671*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3)672*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3) {
673*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
674*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
675*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
676*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
677*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
678*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
679*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
680*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
681*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
682*4bdc9457SAndroid Build Coastguard Worker }
683*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_zero_weights)684*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_zero_weights) {
685*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
686*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
687*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
688*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
689*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
690*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
691*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
692*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
693*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
694*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
695*4bdc9457SAndroid Build Coastguard Worker }
696*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_varying_input_height)697*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_varying_input_height) {
698*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
699*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
700*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
701*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
702*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
703*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
704*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
705*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
706*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
707*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
708*4bdc9457SAndroid Build Coastguard Worker   }
709*4bdc9457SAndroid Build Coastguard Worker }
710*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_varying_input_width)711*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_varying_input_width) {
712*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
713*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
714*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
715*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
716*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
717*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
718*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
719*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
720*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
721*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
722*4bdc9457SAndroid Build Coastguard Worker   }
723*4bdc9457SAndroid Build Coastguard Worker }
724*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_varying_channels)725*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_varying_channels) {
726*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
727*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
728*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
729*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
730*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
731*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
732*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
733*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
734*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
735*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
736*4bdc9457SAndroid Build Coastguard Worker   }
737*4bdc9457SAndroid Build Coastguard Worker }
738*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_with_input_stride)739*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_with_input_stride) {
740*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
741*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
742*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
743*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
744*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
745*4bdc9457SAndroid Build Coastguard Worker     .input_channel_stride(21)
746*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
747*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
748*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
749*4bdc9457SAndroid Build Coastguard Worker }
750*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_with_output_stride)751*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_with_output_stride) {
752*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
753*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
754*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
755*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
756*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
757*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(23)
758*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
759*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
760*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
761*4bdc9457SAndroid Build Coastguard Worker }
762*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_with_qmin)763*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_with_qmin) {
764*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
765*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
766*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
767*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
768*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
769*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
770*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
771*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
772*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
773*4bdc9457SAndroid Build Coastguard Worker }
774*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_with_qmax)775*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_with_qmax) {
776*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
777*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
778*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
779*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
780*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
781*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
782*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
783*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
784*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
785*4bdc9457SAndroid Build Coastguard Worker }
786*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3_without_bias)787*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3_without_bias) {
788*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
789*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
790*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
791*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
792*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
793*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
794*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
795*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
796*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
797*4bdc9457SAndroid Build Coastguard Worker }
798*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,weights_cache_batched_depthwise_3x3)799*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, weights_cache_batched_depthwise_3x3) {
800*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
801*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
802*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
803*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
804*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
805*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
806*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
807*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
808*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
809*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
810*4bdc9457SAndroid Build Coastguard Worker }
811*4bdc9457SAndroid Build Coastguard Worker 
812*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 stride-2 path ****************************/
813*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2)814*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2) {
815*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
816*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
817*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
818*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
819*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
820*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
821*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
822*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
823*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
824*4bdc9457SAndroid Build Coastguard Worker }
825*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_zero_weights)826*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_zero_weights) {
827*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
828*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
829*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
830*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
831*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
832*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
833*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
834*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
835*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
836*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
837*4bdc9457SAndroid Build Coastguard Worker }
838*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_varying_input_height)839*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_varying_input_height) {
840*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
841*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
842*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
843*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
844*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
845*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
846*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
847*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
848*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
849*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
850*4bdc9457SAndroid Build Coastguard Worker   }
851*4bdc9457SAndroid Build Coastguard Worker }
852*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_varying_input_width)853*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_varying_input_width) {
854*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
855*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
856*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
857*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
858*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
859*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
860*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
861*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
862*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
863*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
864*4bdc9457SAndroid Build Coastguard Worker   }
865*4bdc9457SAndroid Build Coastguard Worker }
866*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_varying_channels)867*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_varying_channels) {
868*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
869*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
870*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
871*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
872*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
873*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
874*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
875*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
876*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
877*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
878*4bdc9457SAndroid Build Coastguard Worker   }
879*4bdc9457SAndroid Build Coastguard Worker }
880*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_with_qmin)881*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_with_qmin) {
882*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
883*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
884*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
885*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
886*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
887*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
888*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
889*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
890*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
891*4bdc9457SAndroid Build Coastguard Worker }
892*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_with_qmax)893*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_with_qmax) {
894*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
895*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
896*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
897*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
898*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
899*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
900*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
901*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
902*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
903*4bdc9457SAndroid Build Coastguard Worker }
904*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_3x3s2_without_bias)905*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_3x3s2_without_bias) {
906*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
907*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
908*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
909*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
910*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
911*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
912*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
913*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
914*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
915*4bdc9457SAndroid Build Coastguard Worker }
916*4bdc9457SAndroid Build Coastguard Worker 
917*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 stride-2 path, batched ****************************/
918*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2)919*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2) {
920*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
921*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
922*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
923*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
924*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
925*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
926*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
927*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
928*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
929*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
930*4bdc9457SAndroid Build Coastguard Worker }
931*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_zero_weights)932*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_zero_weights) {
933*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
934*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
935*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
936*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
937*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
938*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
939*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
940*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
941*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
942*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
943*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
944*4bdc9457SAndroid Build Coastguard Worker }
945*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_varying_input_height)946*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_varying_input_height) {
947*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
948*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
949*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
950*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
951*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
952*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
953*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
954*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
955*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
956*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
957*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
958*4bdc9457SAndroid Build Coastguard Worker   }
959*4bdc9457SAndroid Build Coastguard Worker }
960*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_varying_input_width)961*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_varying_input_width) {
962*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
963*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
964*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
965*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
966*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
967*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
968*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
969*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
970*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
971*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
972*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
973*4bdc9457SAndroid Build Coastguard Worker   }
974*4bdc9457SAndroid Build Coastguard Worker }
975*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_varying_channels)976*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_varying_channels) {
977*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
978*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
979*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
980*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
981*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
982*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
983*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
984*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
985*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
986*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
987*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
988*4bdc9457SAndroid Build Coastguard Worker   }
989*4bdc9457SAndroid Build Coastguard Worker }
990*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_with_input_stride)991*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_with_input_stride) {
992*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
993*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
994*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
995*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
996*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
997*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
998*4bdc9457SAndroid Build Coastguard Worker     .input_channel_stride(21)
999*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1000*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1001*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1002*4bdc9457SAndroid Build Coastguard Worker }
1003*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_with_output_stride)1004*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_with_output_stride) {
1005*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1006*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1007*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1008*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1009*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1010*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1011*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(23)
1012*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1013*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1014*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1015*4bdc9457SAndroid Build Coastguard Worker }
1016*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_with_qmin)1017*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_with_qmin) {
1018*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1019*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1020*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1021*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1022*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1023*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1024*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1025*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
1026*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1027*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1028*4bdc9457SAndroid Build Coastguard Worker }
1029*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_with_qmax)1030*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_with_qmax) {
1031*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1032*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1033*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1034*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1035*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1036*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1037*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1038*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
1039*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1040*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1041*4bdc9457SAndroid Build Coastguard Worker }
1042*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_3x3s2_without_bias)1043*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_3x3s2_without_bias) {
1044*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1045*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1046*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1047*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1048*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1049*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1050*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1051*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1052*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1053*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1054*4bdc9457SAndroid Build Coastguard Worker }
1055*4bdc9457SAndroid Build Coastguard Worker 
1056*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 path ****************************/
1057*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5)1058*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5) {
1059*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1060*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1061*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1062*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1063*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1064*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1065*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1066*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1067*4bdc9457SAndroid Build Coastguard Worker }
1068*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_zero_weights)1069*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_zero_weights) {
1070*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1071*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1072*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1073*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1074*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1075*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1076*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
1077*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1078*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1079*4bdc9457SAndroid Build Coastguard Worker }
1080*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_varying_input_height)1081*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_varying_input_height) {
1082*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1083*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
1084*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1085*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
1086*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1087*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1088*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1089*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1090*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1091*4bdc9457SAndroid Build Coastguard Worker   }
1092*4bdc9457SAndroid Build Coastguard Worker }
1093*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_varying_input_width)1094*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_varying_input_width) {
1095*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1096*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
1097*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1098*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
1099*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1100*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1101*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1102*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1103*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1104*4bdc9457SAndroid Build Coastguard Worker   }
1105*4bdc9457SAndroid Build Coastguard Worker }
1106*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_varying_channels)1107*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_varying_channels) {
1108*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1109*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1110*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1111*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1112*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1113*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1114*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1115*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1116*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1117*4bdc9457SAndroid Build Coastguard Worker   }
1118*4bdc9457SAndroid Build Coastguard Worker }
1119*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_with_qmin)1120*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_with_qmin) {
1121*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1122*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1123*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1124*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1125*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1126*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
1127*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1128*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1129*4bdc9457SAndroid Build Coastguard Worker }
1130*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_with_qmax)1131*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_with_qmax) {
1132*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1133*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1134*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1135*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1136*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1137*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
1138*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1139*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1140*4bdc9457SAndroid Build Coastguard Worker }
1141*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5_without_bias)1142*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5_without_bias) {
1143*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1144*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1145*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1146*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1147*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1148*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1149*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1150*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1151*4bdc9457SAndroid Build Coastguard Worker }
1152*4bdc9457SAndroid Build Coastguard Worker 
1153*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 path, batched ****************************/
1154*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5)1155*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5) {
1156*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1157*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1158*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1159*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1160*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1161*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1162*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1163*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1164*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1165*4bdc9457SAndroid Build Coastguard Worker }
1166*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_zero_weights)1167*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_zero_weights) {
1168*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1169*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1170*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1171*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1172*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1173*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1174*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1175*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
1176*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1177*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_varying_input_height)1180*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_varying_input_height) {
1181*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1182*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
1183*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1184*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1185*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
1186*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1187*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1188*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1189*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1190*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1191*4bdc9457SAndroid Build Coastguard Worker   }
1192*4bdc9457SAndroid Build Coastguard Worker }
1193*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_varying_input_width)1194*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_varying_input_width) {
1195*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1196*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
1197*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1198*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1199*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
1200*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1201*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1202*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1203*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1204*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1205*4bdc9457SAndroid Build Coastguard Worker   }
1206*4bdc9457SAndroid Build Coastguard Worker }
1207*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_varying_channels)1208*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_varying_channels) {
1209*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1210*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1211*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1212*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1213*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1214*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1215*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1216*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1217*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1218*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1219*4bdc9457SAndroid Build Coastguard Worker   }
1220*4bdc9457SAndroid Build Coastguard Worker }
1221*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_with_input_stride)1222*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_with_input_stride) {
1223*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1224*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1225*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1226*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1227*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1228*4bdc9457SAndroid Build Coastguard Worker     .input_channel_stride(21)
1229*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1230*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1231*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1232*4bdc9457SAndroid Build Coastguard Worker }
1233*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_with_output_stride)1234*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_with_output_stride) {
1235*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1236*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1237*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1238*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1239*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1240*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(23)
1241*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1242*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1243*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1244*4bdc9457SAndroid Build Coastguard Worker }
1245*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_with_qmin)1246*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_with_qmin) {
1247*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1248*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1249*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1250*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1251*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1252*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1253*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
1254*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1255*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1256*4bdc9457SAndroid Build Coastguard Worker }
1257*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_with_qmax)1258*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_with_qmax) {
1259*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1260*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1261*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1262*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1263*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1264*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1265*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
1266*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1267*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1268*4bdc9457SAndroid Build Coastguard Worker }
1269*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5_without_bias)1270*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5_without_bias) {
1271*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1272*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1273*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1274*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1275*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1276*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1277*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1278*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1279*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1280*4bdc9457SAndroid Build Coastguard Worker }
1281*4bdc9457SAndroid Build Coastguard Worker 
1282*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 stride-2 path ****************************/
1283*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2)1284*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2) {
1285*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1286*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1287*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1288*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1289*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1290*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1291*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1292*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1293*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1294*4bdc9457SAndroid Build Coastguard Worker }
1295*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_zero_weights)1296*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_zero_weights) {
1297*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1298*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1299*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1300*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1301*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1302*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1303*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1304*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
1305*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1306*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1307*4bdc9457SAndroid Build Coastguard Worker }
1308*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_varying_input_height)1309*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_varying_input_height) {
1310*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1311*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
1312*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1313*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
1314*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1315*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1316*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1317*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1318*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1319*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1320*4bdc9457SAndroid Build Coastguard Worker   }
1321*4bdc9457SAndroid Build Coastguard Worker }
1322*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_varying_input_width)1323*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_varying_input_width) {
1324*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1325*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
1326*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1327*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
1328*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1329*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1330*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1331*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1332*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1333*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1334*4bdc9457SAndroid Build Coastguard Worker   }
1335*4bdc9457SAndroid Build Coastguard Worker }
1336*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_varying_channels)1337*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_varying_channels) {
1338*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1339*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1340*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1341*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1342*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1343*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1344*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1345*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1346*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1347*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1348*4bdc9457SAndroid Build Coastguard Worker   }
1349*4bdc9457SAndroid Build Coastguard Worker }
1350*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_with_qmin)1351*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_with_qmin) {
1352*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1353*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1354*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1355*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1356*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1357*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1358*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
1359*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1360*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1361*4bdc9457SAndroid Build Coastguard Worker }
1362*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_with_qmax)1363*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_with_qmax) {
1364*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1365*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1366*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1367*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1368*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1369*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1370*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
1371*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1372*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1373*4bdc9457SAndroid Build Coastguard Worker }
1374*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,depthwise_5x5s2_without_bias)1375*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, depthwise_5x5s2_without_bias) {
1376*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1377*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1378*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1379*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1380*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1381*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1382*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1383*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1384*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1385*4bdc9457SAndroid Build Coastguard Worker }
1386*4bdc9457SAndroid Build Coastguard Worker 
1387*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 stride-2 path, batched ****************************/
1388*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2)1389*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2) {
1390*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1391*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1392*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1393*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1394*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1395*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1396*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1397*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1398*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1399*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1400*4bdc9457SAndroid Build Coastguard Worker }
1401*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_zero_weights)1402*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_zero_weights) {
1403*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1404*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1405*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1406*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1407*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1408*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1409*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1410*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1411*4bdc9457SAndroid Build Coastguard Worker     .sparsity(1.0f)
1412*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1413*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1414*4bdc9457SAndroid Build Coastguard Worker }
1415*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_varying_input_height)1416*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_varying_input_height) {
1417*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1418*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_height = 25; input_height <= 31; input_height++) {
1419*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1420*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1421*4bdc9457SAndroid Build Coastguard Worker       .input_size(input_height, 29)
1422*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1423*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1424*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1425*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1426*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1427*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1428*4bdc9457SAndroid Build Coastguard Worker   }
1429*4bdc9457SAndroid Build Coastguard Worker }
1430*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_varying_input_width)1431*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_varying_input_width) {
1432*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1433*4bdc9457SAndroid Build Coastguard Worker   for (size_t input_width = 27; input_width <= 33; input_width++) {
1434*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1435*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1436*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, input_width)
1437*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1438*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1439*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1440*4bdc9457SAndroid Build Coastguard Worker       .groups(19)
1441*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1442*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1443*4bdc9457SAndroid Build Coastguard Worker   }
1444*4bdc9457SAndroid Build Coastguard Worker }
1445*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_varying_channels)1446*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_varying_channels) {
1447*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1448*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1449*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1450*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1451*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1452*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1453*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1454*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1455*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1456*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1457*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1458*4bdc9457SAndroid Build Coastguard Worker   }
1459*4bdc9457SAndroid Build Coastguard Worker }
1460*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_with_input_stride)1461*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_with_input_stride) {
1462*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1463*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1464*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1465*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1466*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1467*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1468*4bdc9457SAndroid Build Coastguard Worker     .input_channel_stride(21)
1469*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1470*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1471*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1472*4bdc9457SAndroid Build Coastguard Worker }
1473*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_with_output_stride)1474*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_with_output_stride) {
1475*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1476*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1477*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1478*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1479*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1480*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1481*4bdc9457SAndroid Build Coastguard Worker     .output_channel_stride(23)
1482*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1483*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1484*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1485*4bdc9457SAndroid Build Coastguard Worker }
1486*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_with_qmin)1487*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_with_qmin) {
1488*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1489*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1490*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1491*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1492*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1493*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1494*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1495*4bdc9457SAndroid Build Coastguard Worker     .qmin(128)
1496*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1497*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1498*4bdc9457SAndroid Build Coastguard Worker }
1499*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_with_qmax)1500*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_with_qmax) {
1501*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1502*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1503*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1504*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1505*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1506*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1507*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1508*4bdc9457SAndroid Build Coastguard Worker     .qmax(128)
1509*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1510*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1511*4bdc9457SAndroid Build Coastguard Worker }
1512*4bdc9457SAndroid Build Coastguard Worker 
TEST(CONVOLUTION_NCHW_F32,batched_depthwise_5x5s2_without_bias)1513*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NCHW_F32, batched_depthwise_5x5s2_without_bias) {
1514*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1515*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1516*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1517*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1518*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1519*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1520*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1521*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1522*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1523*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1524*4bdc9457SAndroid Build Coastguard Worker }
1525*4bdc9457SAndroid Build Coastguard Worker 
1526*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 path ****************************/
1527*4bdc9457SAndroid Build Coastguard Worker 
1528*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3) {
1529*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1530*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1531*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1532*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1533*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1534*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1535*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1536*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1537*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1538*4bdc9457SAndroid Build Coastguard Worker }
1539*4bdc9457SAndroid Build Coastguard Worker 
1540*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3_varying_channels) {
1541*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1542*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1543*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1544*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1545*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1546*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
1547*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
1548*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1549*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1550*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1551*4bdc9457SAndroid Build Coastguard Worker   }
1552*4bdc9457SAndroid Build Coastguard Worker }
1553*4bdc9457SAndroid Build Coastguard Worker 
1554*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3_without_bias) {
1555*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1556*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1557*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1558*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1559*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1560*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1561*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1562*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1563*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1564*4bdc9457SAndroid Build Coastguard Worker }
1565*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,weights_cache_3x3)1566*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, weights_cache_3x3) {
1567*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1568*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1569*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1570*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1571*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1572*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1573*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1574*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
1575*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1576*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1577*4bdc9457SAndroid Build Coastguard Worker }
1578*4bdc9457SAndroid Build Coastguard Worker 
1579*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 path, batched ****************************/
1580*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3)1581*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3) {
1582*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1583*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1584*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1585*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1586*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1587*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1588*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1589*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1590*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1591*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1592*4bdc9457SAndroid Build Coastguard Worker }
1593*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3_varying_channels)1594*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3_varying_channels) {
1595*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1596*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1597*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1598*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1599*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1600*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1601*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
1602*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
1603*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1604*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1605*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1606*4bdc9457SAndroid Build Coastguard Worker   }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3_without_bias)1609*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3_without_bias) {
1610*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1611*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1612*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1613*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1614*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1615*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1616*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1617*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1618*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1619*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1620*4bdc9457SAndroid Build Coastguard Worker }
1621*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,weights_cache_batched_3x3)1622*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, weights_cache_batched_3x3) {
1623*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1624*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1625*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1626*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1627*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1628*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1629*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1630*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1631*4bdc9457SAndroid Build Coastguard Worker     .use_weights_cache(true)
1632*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1633*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1634*4bdc9457SAndroid Build Coastguard Worker }
1635*4bdc9457SAndroid Build Coastguard Worker 
1636*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 stride-2 path ****************************/
1637*4bdc9457SAndroid Build Coastguard Worker 
1638*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3s2) {
1639*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1640*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1641*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1642*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1643*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1644*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1645*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1646*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1647*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1648*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1649*4bdc9457SAndroid Build Coastguard Worker }
1650*4bdc9457SAndroid Build Coastguard Worker 
1651*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3s2_varying_channels) {
1652*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1653*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1654*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1655*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1656*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1657*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
1658*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
1659*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1660*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1661*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1662*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1663*4bdc9457SAndroid Build Coastguard Worker   }
1664*4bdc9457SAndroid Build Coastguard Worker }
1665*4bdc9457SAndroid Build Coastguard Worker 
1666*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 3x3s2_without_bias) {
1667*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1668*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1669*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1670*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1671*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1672*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1673*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1674*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1675*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1676*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1677*4bdc9457SAndroid Build Coastguard Worker }
1678*4bdc9457SAndroid Build Coastguard Worker 
1679*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 3x3 stride-2 path, batched ****************************/
1680*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3s2)1681*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3s2) {
1682*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1683*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1684*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1685*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1686*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1687*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1688*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1689*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1690*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1691*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1692*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1693*4bdc9457SAndroid Build Coastguard Worker }
1694*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3s2_varying_channels)1695*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3s2_varying_channels) {
1696*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1697*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1698*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1699*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1700*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1701*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1702*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(3, 3)
1703*4bdc9457SAndroid Build Coastguard Worker       .padding(1)
1704*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1705*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1706*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1707*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1708*4bdc9457SAndroid Build Coastguard Worker   }
1709*4bdc9457SAndroid Build Coastguard Worker }
1710*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_3x3s2_without_bias)1711*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_3x3s2_without_bias) {
1712*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1713*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1714*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1715*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1716*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1717*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(3, 3)
1718*4bdc9457SAndroid Build Coastguard Worker     .padding(1)
1719*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1720*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1721*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1722*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1723*4bdc9457SAndroid Build Coastguard Worker }
1724*4bdc9457SAndroid Build Coastguard Worker 
1725*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 path ****************************/
1726*4bdc9457SAndroid Build Coastguard Worker 
1727*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5) {
1728*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1729*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1730*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1731*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1732*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1733*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1734*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1735*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1736*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1737*4bdc9457SAndroid Build Coastguard Worker }
1738*4bdc9457SAndroid Build Coastguard Worker 
1739*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5_varying_channels) {
1740*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1741*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1742*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1743*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1744*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1745*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1746*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1747*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1748*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1749*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1750*4bdc9457SAndroid Build Coastguard Worker   }
1751*4bdc9457SAndroid Build Coastguard Worker }
1752*4bdc9457SAndroid Build Coastguard Worker 
1753*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5_without_bias) {
1754*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1755*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1756*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1757*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1758*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1759*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1760*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1761*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1762*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1763*4bdc9457SAndroid Build Coastguard Worker }
1764*4bdc9457SAndroid Build Coastguard Worker 
1765*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 path, batched ****************************/
1766*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5)1767*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5) {
1768*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1769*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1770*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1771*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1772*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1773*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1774*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1775*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1776*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1777*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1778*4bdc9457SAndroid Build Coastguard Worker }
1779*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5_varying_channels)1780*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5_varying_channels) {
1781*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1782*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1783*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1784*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1785*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1786*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1787*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1788*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1789*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1790*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1791*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1792*4bdc9457SAndroid Build Coastguard Worker   }
1793*4bdc9457SAndroid Build Coastguard Worker }
1794*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5_without_bias)1795*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5_without_bias) {
1796*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1797*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1798*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1799*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1800*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1801*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1802*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1803*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1804*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1805*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1806*4bdc9457SAndroid Build Coastguard Worker }
1807*4bdc9457SAndroid Build Coastguard Worker 
1808*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 stride-2 path ****************************/
1809*4bdc9457SAndroid Build Coastguard Worker 
1810*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5s2) {
1811*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1812*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1813*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1814*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1815*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1816*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1817*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1818*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1819*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1820*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1821*4bdc9457SAndroid Build Coastguard Worker }
1822*4bdc9457SAndroid Build Coastguard Worker 
1823*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5s2_varying_channels) {
1824*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1825*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1826*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1827*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1828*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1829*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1830*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1831*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1832*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1833*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1834*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1835*4bdc9457SAndroid Build Coastguard Worker   }
1836*4bdc9457SAndroid Build Coastguard Worker }
1837*4bdc9457SAndroid Build Coastguard Worker 
1838*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, 5x5s2_without_bias) {
1839*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1840*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1841*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1842*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1843*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1844*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1845*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1846*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1847*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1848*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1849*4bdc9457SAndroid Build Coastguard Worker }
1850*4bdc9457SAndroid Build Coastguard Worker 
1851*4bdc9457SAndroid Build Coastguard Worker /**************************** DWCONV 5x5 stride-2 path, batched ****************************/
1852*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5s2)1853*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5s2) {
1854*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1855*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1856*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1857*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1858*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1859*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1860*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1861*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1862*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1863*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1864*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1865*4bdc9457SAndroid Build Coastguard Worker }
1866*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5s2_varying_channels)1867*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5s2_varying_channels) {
1868*4bdc9457SAndroid Build Coastguard Worker   ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1869*4bdc9457SAndroid Build Coastguard Worker   for (size_t channels = 1; channels <= 16; channels *= 4) {
1870*4bdc9457SAndroid Build Coastguard Worker     ConvolutionOperatorTester()
1871*4bdc9457SAndroid Build Coastguard Worker       .depthwise_layout(true)
1872*4bdc9457SAndroid Build Coastguard Worker       .batch_size(2)
1873*4bdc9457SAndroid Build Coastguard Worker       .input_size(27, 29)
1874*4bdc9457SAndroid Build Coastguard Worker       .kernel_size(5, 5)
1875*4bdc9457SAndroid Build Coastguard Worker       .padding(2)
1876*4bdc9457SAndroid Build Coastguard Worker       .subsampling(2)
1877*4bdc9457SAndroid Build Coastguard Worker       .groups(channels)
1878*4bdc9457SAndroid Build Coastguard Worker       .iterations(1)
1879*4bdc9457SAndroid Build Coastguard Worker       .TestNCHWxF32();
1880*4bdc9457SAndroid Build Coastguard Worker   }
1881*4bdc9457SAndroid Build Coastguard Worker }
1882*4bdc9457SAndroid Build Coastguard Worker 
TEST(DEPTHWISE_CONVOLUTION_NCHW_F32,batched_5x5s2_without_bias)1883*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NCHW_F32, batched_5x5s2_without_bias) {
1884*4bdc9457SAndroid Build Coastguard Worker   ConvolutionOperatorTester()
1885*4bdc9457SAndroid Build Coastguard Worker     .depthwise_layout(true)
1886*4bdc9457SAndroid Build Coastguard Worker     .has_bias(false)
1887*4bdc9457SAndroid Build Coastguard Worker     .batch_size(2)
1888*4bdc9457SAndroid Build Coastguard Worker     .input_size(27, 29)
1889*4bdc9457SAndroid Build Coastguard Worker     .kernel_size(5, 5)
1890*4bdc9457SAndroid Build Coastguard Worker     .padding(2)
1891*4bdc9457SAndroid Build Coastguard Worker     .subsampling(2)
1892*4bdc9457SAndroid Build Coastguard Worker     .groups(19)
1893*4bdc9457SAndroid Build Coastguard Worker     .iterations(3)
1894*4bdc9457SAndroid Build Coastguard Worker     .TestNCHWxF32();
1895*4bdc9457SAndroid Build Coastguard Worker }
1896