1*4bdc9457SAndroid Build Coastguard Worker // Copyright (c) Facebook, Inc. and its affiliates.
2*4bdc9457SAndroid Build Coastguard Worker // All rights reserved.
3*4bdc9457SAndroid Build Coastguard Worker //
4*4bdc9457SAndroid Build Coastguard Worker // Copyright 2019 Google LLC
5*4bdc9457SAndroid Build Coastguard Worker //
6*4bdc9457SAndroid Build Coastguard Worker // This source code is licensed under the BSD-style license found in the
7*4bdc9457SAndroid Build Coastguard Worker // LICENSE file in the root directory of this source tree.
8*4bdc9457SAndroid Build Coastguard Worker
9*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/common.h>
10*4bdc9457SAndroid Build Coastguard Worker
11*4bdc9457SAndroid Build Coastguard Worker #include <gtest/gtest.h>
12*4bdc9457SAndroid Build Coastguard Worker
13*4bdc9457SAndroid Build Coastguard Worker #include "convolution-operator-tester.h"
14*4bdc9457SAndroid Build Coastguard Worker
15*4bdc9457SAndroid Build Coastguard Worker
16*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1) {
17*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
18*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
19*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
20*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
21*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
22*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
23*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
24*4bdc9457SAndroid Build Coastguard Worker }
25*4bdc9457SAndroid Build Coastguard Worker
26*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_with_qmin) {
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 .qmin(128)
33*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
34*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
35*4bdc9457SAndroid Build Coastguard Worker }
36*4bdc9457SAndroid Build Coastguard Worker
37*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_with_qmax) {
38*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
39*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
40*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
41*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
42*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
43*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
44*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
45*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
46*4bdc9457SAndroid Build Coastguard Worker }
47*4bdc9457SAndroid Build Coastguard Worker
48*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_with_input_stride) {
49*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
50*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
51*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
52*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
53*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
54*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
55*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
56*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
57*4bdc9457SAndroid Build Coastguard Worker }
58*4bdc9457SAndroid Build Coastguard Worker
59*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_with_output_stride) {
60*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
61*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
62*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
63*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
64*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
65*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
66*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
67*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
68*4bdc9457SAndroid Build Coastguard Worker }
69*4bdc9457SAndroid Build Coastguard Worker
70*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_without_bias) {
71*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
72*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
73*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
74*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
75*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
76*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
77*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
78*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
79*4bdc9457SAndroid Build Coastguard Worker }
80*4bdc9457SAndroid Build Coastguard Worker
81*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x1_with_batch) {
82*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
83*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
84*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
85*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
86*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
87*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
88*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
89*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
90*4bdc9457SAndroid Build Coastguard Worker }
91*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1)92*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1) {
93*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
94*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
95*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
96*4bdc9457SAndroid Build Coastguard Worker .groups(2)
97*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
98*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
99*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
100*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
101*4bdc9457SAndroid Build Coastguard Worker }
102*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_with_qmin)103*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_with_qmin) {
104*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
105*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
106*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
107*4bdc9457SAndroid Build Coastguard Worker .groups(2)
108*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
109*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
110*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
111*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
112*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
113*4bdc9457SAndroid Build Coastguard Worker }
114*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_with_qmax)115*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_with_qmax) {
116*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
117*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
118*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
119*4bdc9457SAndroid Build Coastguard Worker .groups(2)
120*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
121*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
122*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
123*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
124*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
125*4bdc9457SAndroid Build Coastguard Worker }
126*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_with_input_stride)127*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_with_input_stride) {
128*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
129*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
130*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
131*4bdc9457SAndroid Build Coastguard Worker .groups(2)
132*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
133*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
134*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
135*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
136*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
137*4bdc9457SAndroid Build Coastguard Worker }
138*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_with_output_stride)139*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_with_output_stride) {
140*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
141*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
142*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
143*4bdc9457SAndroid Build Coastguard Worker .groups(2)
144*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
145*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
146*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
147*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
148*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
149*4bdc9457SAndroid Build Coastguard Worker }
150*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_without_bias)151*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_without_bias) {
152*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
153*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
154*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
155*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
156*4bdc9457SAndroid Build Coastguard Worker .groups(2)
157*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
158*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
159*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
160*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
161*4bdc9457SAndroid Build Coastguard Worker }
162*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x1_with_batch)163*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x1_with_batch) {
164*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
165*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
166*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
167*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
168*4bdc9457SAndroid Build Coastguard Worker .groups(2)
169*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
170*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
171*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
172*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
173*4bdc9457SAndroid Build Coastguard Worker }
174*4bdc9457SAndroid Build Coastguard Worker
175*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 1x3) {
176*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
177*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
178*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
179*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
180*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
181*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
182*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
183*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
184*4bdc9457SAndroid Build Coastguard Worker }
185*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_1x3)186*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_1x3) {
187*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
188*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
189*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
190*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
191*4bdc9457SAndroid Build Coastguard Worker .groups(2)
192*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
193*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
194*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
195*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
196*4bdc9457SAndroid Build Coastguard Worker }
197*4bdc9457SAndroid Build Coastguard Worker
198*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x1) {
199*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
200*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
201*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
202*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
203*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
204*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
205*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
206*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
207*4bdc9457SAndroid Build Coastguard Worker }
208*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x1)209*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x1) {
210*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
211*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
212*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
213*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
214*4bdc9457SAndroid Build Coastguard Worker .groups(2)
215*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
216*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
217*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
218*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
219*4bdc9457SAndroid Build Coastguard Worker }
220*4bdc9457SAndroid Build Coastguard Worker
221*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3) {
222*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
223*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
224*4bdc9457SAndroid Build Coastguard Worker .padding(1)
225*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
226*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
227*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
228*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
229*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
230*4bdc9457SAndroid Build Coastguard Worker }
231*4bdc9457SAndroid Build Coastguard Worker
232*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_without_padding) {
233*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
234*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
235*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
236*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
237*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
238*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
239*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
240*4bdc9457SAndroid Build Coastguard Worker }
241*4bdc9457SAndroid Build Coastguard Worker
242*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_left_padding) {
243*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
244*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
245*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
246*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
247*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
248*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
249*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
250*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
251*4bdc9457SAndroid Build Coastguard Worker }
252*4bdc9457SAndroid Build Coastguard Worker
253*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_right_padding) {
254*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
255*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
256*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
257*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
258*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
259*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
260*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
261*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
262*4bdc9457SAndroid Build Coastguard Worker }
263*4bdc9457SAndroid Build Coastguard Worker
264*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_top_padding) {
265*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
266*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
267*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
268*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
269*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
270*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
271*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
272*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
273*4bdc9457SAndroid Build Coastguard Worker }
274*4bdc9457SAndroid Build Coastguard Worker
275*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_bottom_padding) {
276*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
277*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
278*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
279*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
280*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
281*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
282*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
283*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
284*4bdc9457SAndroid Build Coastguard Worker }
285*4bdc9457SAndroid Build Coastguard Worker
286*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_input_stride) {
287*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
288*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
289*4bdc9457SAndroid Build Coastguard Worker .padding(1)
290*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
291*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
292*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
293*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
294*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
295*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
296*4bdc9457SAndroid Build Coastguard Worker }
297*4bdc9457SAndroid Build Coastguard Worker
298*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_output_stride) {
299*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
300*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
301*4bdc9457SAndroid Build Coastguard Worker .padding(1)
302*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
303*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
304*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
305*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
306*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
307*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
308*4bdc9457SAndroid Build Coastguard Worker }
309*4bdc9457SAndroid Build Coastguard Worker
310*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_without_bias) {
311*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
312*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
313*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
314*4bdc9457SAndroid Build Coastguard Worker .padding(1)
315*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
316*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
317*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
318*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
319*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
320*4bdc9457SAndroid Build Coastguard Worker }
321*4bdc9457SAndroid Build Coastguard Worker
322*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3_with_batch) {
323*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
324*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
325*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
326*4bdc9457SAndroid Build Coastguard Worker .padding(1)
327*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
328*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
329*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
330*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
331*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
332*4bdc9457SAndroid Build Coastguard Worker }
333*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3)334*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3) {
335*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
336*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
337*4bdc9457SAndroid Build Coastguard Worker .padding(1)
338*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
339*4bdc9457SAndroid Build Coastguard Worker .groups(2)
340*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
341*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
342*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
343*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
344*4bdc9457SAndroid Build Coastguard Worker }
345*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_without_padding)346*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_without_padding) {
347*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
348*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
349*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
350*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
351*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
352*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
353*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
354*4bdc9457SAndroid Build Coastguard Worker }
355*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_left_padding)356*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_left_padding) {
357*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
358*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
359*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
360*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
361*4bdc9457SAndroid Build Coastguard Worker .groups(2)
362*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
363*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
364*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
365*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
366*4bdc9457SAndroid Build Coastguard Worker }
367*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_right_padding)368*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_right_padding) {
369*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
370*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
371*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
372*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
373*4bdc9457SAndroid Build Coastguard Worker .groups(2)
374*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
375*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
376*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
377*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
378*4bdc9457SAndroid Build Coastguard Worker }
379*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_top_padding)380*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_top_padding) {
381*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
382*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
383*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
384*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
385*4bdc9457SAndroid Build Coastguard Worker .groups(2)
386*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
387*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
388*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
389*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
390*4bdc9457SAndroid Build Coastguard Worker }
391*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_bottom_padding)392*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_bottom_padding) {
393*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
394*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
395*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
396*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
397*4bdc9457SAndroid Build Coastguard Worker .groups(2)
398*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
399*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
400*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
401*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
402*4bdc9457SAndroid Build Coastguard Worker }
403*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_input_stride)404*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_input_stride) {
405*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
406*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
407*4bdc9457SAndroid Build Coastguard Worker .padding(1)
408*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
409*4bdc9457SAndroid Build Coastguard Worker .groups(2)
410*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
411*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
412*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
413*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
414*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
415*4bdc9457SAndroid Build Coastguard Worker }
416*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_output_stride)417*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_output_stride) {
418*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
419*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
420*4bdc9457SAndroid Build Coastguard Worker .padding(1)
421*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
422*4bdc9457SAndroid Build Coastguard Worker .groups(2)
423*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
424*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
425*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
426*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
427*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
428*4bdc9457SAndroid Build Coastguard Worker }
429*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_without_bias)430*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_without_bias) {
431*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
432*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
433*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
434*4bdc9457SAndroid Build Coastguard Worker .padding(1)
435*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
436*4bdc9457SAndroid Build Coastguard Worker .groups(2)
437*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
438*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
439*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
440*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
441*4bdc9457SAndroid Build Coastguard Worker }
442*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,grouped_3x3_with_batch)443*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, grouped_3x3_with_batch) {
444*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
445*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
446*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
447*4bdc9457SAndroid Build Coastguard Worker .padding(1)
448*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
449*4bdc9457SAndroid Build Coastguard Worker .groups(2)
450*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
451*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
452*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
453*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
454*4bdc9457SAndroid Build Coastguard Worker }
455*4bdc9457SAndroid Build Coastguard Worker
456*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s2) {
457*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
458*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
459*4bdc9457SAndroid Build Coastguard Worker .padding(1)
460*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
461*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
462*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
463*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
464*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
465*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
466*4bdc9457SAndroid Build Coastguard Worker }
467*4bdc9457SAndroid Build Coastguard Worker
468*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s2_with_tf_same_padding) {
469*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
470*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
471*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
472*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
473*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
474*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
475*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
476*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
477*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
478*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
479*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
480*4bdc9457SAndroid Build Coastguard Worker }
481*4bdc9457SAndroid Build Coastguard Worker }
482*4bdc9457SAndroid Build Coastguard Worker }
483*4bdc9457SAndroid Build Coastguard Worker
484*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s1x2) {
485*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
486*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
487*4bdc9457SAndroid Build Coastguard Worker .padding(1)
488*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
489*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
490*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
491*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
492*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
493*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
494*4bdc9457SAndroid Build Coastguard Worker }
495*4bdc9457SAndroid Build Coastguard Worker
496*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s1x2_with_tf_same_padding) {
497*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
498*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
499*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
500*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
501*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
502*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
503*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
504*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
505*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
506*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
507*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
508*4bdc9457SAndroid Build Coastguard Worker }
509*4bdc9457SAndroid Build Coastguard Worker }
510*4bdc9457SAndroid Build Coastguard Worker }
511*4bdc9457SAndroid Build Coastguard Worker
512*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s2x1) {
513*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
514*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
515*4bdc9457SAndroid Build Coastguard Worker .padding(1)
516*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
517*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
518*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
519*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
520*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
521*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
522*4bdc9457SAndroid Build Coastguard Worker }
523*4bdc9457SAndroid Build Coastguard Worker
524*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3s2x1_with_tf_same_padding) {
525*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
526*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
527*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
528*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
529*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
530*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
531*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
532*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
533*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
534*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
535*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
536*4bdc9457SAndroid Build Coastguard Worker }
537*4bdc9457SAndroid Build Coastguard Worker }
538*4bdc9457SAndroid Build Coastguard Worker }
539*4bdc9457SAndroid Build Coastguard Worker
540*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3d2) {
541*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
542*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
543*4bdc9457SAndroid Build Coastguard Worker .padding(2)
544*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
545*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
546*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
547*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
548*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
549*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
550*4bdc9457SAndroid Build Coastguard Worker }
551*4bdc9457SAndroid Build Coastguard Worker
552*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3d1x2) {
553*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
554*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
555*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
556*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
557*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
558*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
559*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
560*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
561*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
562*4bdc9457SAndroid Build Coastguard Worker }
563*4bdc9457SAndroid Build Coastguard Worker
564*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, 3x3d2x1) {
565*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
566*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
567*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
568*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
569*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
570*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
571*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
572*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
573*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
574*4bdc9457SAndroid Build Coastguard Worker }
575*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3)576*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3) {
577*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
578*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
579*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
580*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
581*4bdc9457SAndroid Build Coastguard Worker .groups(27)
582*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
583*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3_without_bias)586*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3_without_bias) {
587*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
588*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
589*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
590*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
591*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
592*4bdc9457SAndroid Build Coastguard Worker .groups(27)
593*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
594*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
595*4bdc9457SAndroid Build Coastguard Worker }
596*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s2)597*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s2) {
598*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
599*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
600*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
601*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
602*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
603*4bdc9457SAndroid Build Coastguard Worker .groups(27)
604*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
605*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
606*4bdc9457SAndroid Build Coastguard Worker }
607*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s2_with_tf_same_padding)608*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s2_with_tf_same_padding) {
609*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
610*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
611*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
612*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
613*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
614*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
615*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
616*4bdc9457SAndroid Build Coastguard Worker .groups(27)
617*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
618*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
619*4bdc9457SAndroid Build Coastguard Worker }
620*4bdc9457SAndroid Build Coastguard Worker }
621*4bdc9457SAndroid Build Coastguard Worker }
622*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s1x2)623*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s1x2) {
624*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
625*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
626*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
627*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
628*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
629*4bdc9457SAndroid Build Coastguard Worker .groups(27)
630*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
631*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
632*4bdc9457SAndroid Build Coastguard Worker }
633*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s1x2_with_tf_same_padding)634*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s1x2_with_tf_same_padding) {
635*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
636*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
637*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
638*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
639*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
640*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
641*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
642*4bdc9457SAndroid Build Coastguard Worker .groups(27)
643*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
644*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
645*4bdc9457SAndroid Build Coastguard Worker }
646*4bdc9457SAndroid Build Coastguard Worker }
647*4bdc9457SAndroid Build Coastguard Worker }
648*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s2x1)649*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s2x1) {
650*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
651*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
652*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
653*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
654*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
655*4bdc9457SAndroid Build Coastguard Worker .groups(27)
656*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
657*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
658*4bdc9457SAndroid Build Coastguard Worker }
659*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3s2x1_with_tf_same_padding)660*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3s2x1_with_tf_same_padding) {
661*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
662*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
663*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
664*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
665*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
666*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
667*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
668*4bdc9457SAndroid Build Coastguard Worker .groups(27)
669*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
670*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
671*4bdc9457SAndroid Build Coastguard Worker }
672*4bdc9457SAndroid Build Coastguard Worker }
673*4bdc9457SAndroid Build Coastguard Worker }
674*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3d2)675*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3d2) {
676*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
677*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
678*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
679*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
680*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
681*4bdc9457SAndroid Build Coastguard Worker .groups(27)
682*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
683*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
684*4bdc9457SAndroid Build Coastguard Worker }
685*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3d1x2)686*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3d1x2) {
687*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
688*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
689*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
690*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
691*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
692*4bdc9457SAndroid Build Coastguard Worker .groups(27)
693*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
694*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
695*4bdc9457SAndroid Build Coastguard Worker }
696*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,depthwise_3x3d2x1)697*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, depthwise_3x3d2x1) {
698*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
699*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
700*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
701*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
702*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
703*4bdc9457SAndroid Build Coastguard Worker .groups(27)
704*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
705*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
706*4bdc9457SAndroid Build Coastguard Worker }
707*4bdc9457SAndroid Build Coastguard Worker
708*4bdc9457SAndroid Build Coastguard Worker // Tests GEMM microkernel with weights_cache.
TEST(CONVOLUTION_NHWC_QC8,weights_cache_1x1)709*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, weights_cache_1x1) {
710*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
711*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
712*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
713*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
714*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
715*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
716*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
717*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
718*4bdc9457SAndroid Build Coastguard Worker }
719*4bdc9457SAndroid Build Coastguard Worker
720*4bdc9457SAndroid Build Coastguard Worker // Tests IGEMM microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QC8,weights_cache_3x3)721*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, weights_cache_3x3) {
722*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
723*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
724*4bdc9457SAndroid Build Coastguard Worker .padding(1)
725*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
726*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
727*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
728*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
729*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
730*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
731*4bdc9457SAndroid Build Coastguard Worker }
732*4bdc9457SAndroid Build Coastguard Worker
733*4bdc9457SAndroid Build Coastguard Worker // Tests vmulcaddc microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QC8,weights_cache_depthwise_1x1)734*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, weights_cache_depthwise_1x1) {
735*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
736*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
737*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
738*4bdc9457SAndroid Build Coastguard Worker .groups(24)
739*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
740*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
741*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
742*4bdc9457SAndroid Build Coastguard Worker }
743*4bdc9457SAndroid Build Coastguard Worker
744*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QC8,weights_cache_depthwise_2x2d2)745*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, weights_cache_depthwise_2x2d2) {
746*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
747*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
748*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
749*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
750*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
751*4bdc9457SAndroid Build Coastguard Worker .groups(27)
752*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
753*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
754*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
755*4bdc9457SAndroid Build Coastguard Worker }
756*4bdc9457SAndroid Build Coastguard Worker
757*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 1x1) {
758*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
759*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
760*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
761*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
762*4bdc9457SAndroid Build Coastguard Worker .groups(24)
763*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
764*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
765*4bdc9457SAndroid Build Coastguard Worker }
766*4bdc9457SAndroid Build Coastguard Worker
767*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 1x1_with_depth_multiplier) {
768*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
769*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
770*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
771*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
772*4bdc9457SAndroid Build Coastguard Worker .groups(24)
773*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
774*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
775*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
776*4bdc9457SAndroid Build Coastguard Worker }
777*4bdc9457SAndroid Build Coastguard Worker
778*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 1x1_without_bias) {
779*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
780*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
781*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
782*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
783*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
784*4bdc9457SAndroid Build Coastguard Worker .groups(24)
785*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
786*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
787*4bdc9457SAndroid Build Coastguard Worker }
788*4bdc9457SAndroid Build Coastguard Worker
789*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 2x2) {
790*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
791*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
792*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
793*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
794*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
795*4bdc9457SAndroid Build Coastguard Worker .groups(24)
796*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
797*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
798*4bdc9457SAndroid Build Coastguard Worker }
799*4bdc9457SAndroid Build Coastguard Worker
800*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 2x2_with_depth_multiplier) {
801*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
802*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
803*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
804*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
805*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
806*4bdc9457SAndroid Build Coastguard Worker .groups(24)
807*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
808*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
809*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
810*4bdc9457SAndroid Build Coastguard Worker }
811*4bdc9457SAndroid Build Coastguard Worker
812*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 2x2_without_bias) {
813*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
814*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
815*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
816*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
817*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
818*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
819*4bdc9457SAndroid Build Coastguard Worker .groups(24)
820*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
821*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
822*4bdc9457SAndroid Build Coastguard Worker }
823*4bdc9457SAndroid Build Coastguard Worker
824*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 3x3) {
825*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
826*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
827*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
828*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
829*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
830*4bdc9457SAndroid Build Coastguard Worker .groups(24)
831*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
832*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
833*4bdc9457SAndroid Build Coastguard Worker }
834*4bdc9457SAndroid Build Coastguard Worker
835*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 3x3_with_depth_multiplier) {
836*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
837*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
838*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
839*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
840*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
841*4bdc9457SAndroid Build Coastguard Worker .groups(24)
842*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
843*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
844*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
847*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 3x3_without_bias) {
848*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
849*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
850*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
851*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
852*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
853*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
854*4bdc9457SAndroid Build Coastguard Worker .groups(24)
855*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
856*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
857*4bdc9457SAndroid Build Coastguard Worker }
858*4bdc9457SAndroid Build Coastguard Worker
859*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 3x3s2_with_tf_same_padding) {
860*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
861*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
862*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
863*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
864*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
865*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
866*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
867*4bdc9457SAndroid Build Coastguard Worker .groups(24)
868*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
869*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
870*4bdc9457SAndroid Build Coastguard Worker }
871*4bdc9457SAndroid Build Coastguard Worker }
872*4bdc9457SAndroid Build Coastguard Worker }
873*4bdc9457SAndroid Build Coastguard Worker
874*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 5x5) {
875*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
876*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
877*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
878*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
879*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
880*4bdc9457SAndroid Build Coastguard Worker .groups(24)
881*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
882*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
883*4bdc9457SAndroid Build Coastguard Worker }
884*4bdc9457SAndroid Build Coastguard Worker
885*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 5x5_with_depth_multiplier) {
886*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
887*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
888*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
889*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
890*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
891*4bdc9457SAndroid Build Coastguard Worker .groups(24)
892*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
893*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
894*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker
897*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 5x5_without_bias) {
898*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
899*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
900*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
901*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
902*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
903*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
904*4bdc9457SAndroid Build Coastguard Worker .groups(24)
905*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
906*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
907*4bdc9457SAndroid Build Coastguard Worker }
908*4bdc9457SAndroid Build Coastguard Worker
909*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 7x7) {
910*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
911*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
912*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
913*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
914*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
915*4bdc9457SAndroid Build Coastguard Worker .groups(24)
916*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
917*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
918*4bdc9457SAndroid Build Coastguard Worker }
919*4bdc9457SAndroid Build Coastguard Worker
920*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, 7x7_without_bias) {
921*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
922*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
923*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
924*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
925*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
926*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
927*4bdc9457SAndroid Build Coastguard Worker .groups(24)
928*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
929*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
930*4bdc9457SAndroid Build Coastguard Worker }
931*4bdc9457SAndroid Build Coastguard Worker
932*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8,weights_cache_1x1)933*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, weights_cache_1x1) {
934*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
935*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
936*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
937*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
938*4bdc9457SAndroid Build Coastguard Worker .groups(24)
939*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
940*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
941*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
942*4bdc9457SAndroid Build Coastguard Worker }
943*4bdc9457SAndroid Build Coastguard Worker
944*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernek with non 1x1 kernel (dwconv_hwg packing).
TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8,weights_cache_2x2)945*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QC8, weights_cache_2x2) {
946*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
947*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
948*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
949*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
950*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
951*4bdc9457SAndroid Build Coastguard Worker .groups(24)
952*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
953*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
954*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQC8();
955*4bdc9457SAndroid Build Coastguard Worker }
956*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_input_buffer)957*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_input_buffer) {
958*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
959*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
960*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
961*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
962*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
963*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
964*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
965*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
966*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
967*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
968*4bdc9457SAndroid Build Coastguard Worker }
969*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_input_buffer_grouped)970*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_input_buffer_grouped) {
971*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
972*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
973*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
974*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
975*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
976*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
977*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
978*4bdc9457SAndroid Build Coastguard Worker .groups(2)
979*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
980*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
981*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
982*4bdc9457SAndroid Build Coastguard Worker }
983*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_input_buffer_depthwise)984*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_input_buffer_depthwise) {
985*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
986*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
987*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
988*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
989*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
990*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
991*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
992*4bdc9457SAndroid Build Coastguard Worker .groups(19)
993*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
994*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
995*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
996*4bdc9457SAndroid Build Coastguard Worker }
997*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_increasing_batch)998*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_increasing_batch) {
999*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1000*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1001*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1002*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
1003*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1004*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1005*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1006*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1007*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1008*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1009*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1010*4bdc9457SAndroid Build Coastguard Worker }
1011*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_increasing_batch_grouped)1012*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_increasing_batch_grouped) {
1013*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1014*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1015*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1016*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
1017*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1018*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1019*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1020*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1021*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1022*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1023*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1024*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1025*4bdc9457SAndroid Build Coastguard Worker }
1026*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_increasing_batch_depthwise)1027*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_increasing_batch_depthwise) {
1028*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1029*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1030*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1031*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
1032*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1033*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1034*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1035*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1036*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1037*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1038*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1039*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1040*4bdc9457SAndroid Build Coastguard Worker }
1041*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_decreasing_batch)1042*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_decreasing_batch) {
1043*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1044*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1045*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
1046*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
1047*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1048*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1049*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1050*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1051*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1052*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1053*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1054*4bdc9457SAndroid Build Coastguard Worker }
1055*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_decreasing_batch_grouped)1056*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_decreasing_batch_grouped) {
1057*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1058*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1059*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
1060*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
1061*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1062*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1063*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1064*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1065*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1066*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1067*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1068*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_decreasing_batch_depthwise)1071*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_decreasing_batch_depthwise) {
1072*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1073*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1074*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
1075*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
1076*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1077*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1078*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1079*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1080*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1081*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1082*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1083*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1084*4bdc9457SAndroid Build Coastguard Worker }
1085*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_height)1086*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_height) {
1087*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1088*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1089*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1090*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1091*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1092*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
1093*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1094*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1095*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1096*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1097*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1098*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1099*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1100*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1101*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1102*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
1103*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1104*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1105*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1106*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1107*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1108*4bdc9457SAndroid Build Coastguard Worker }
1109*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_height_grouped)1110*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_height_grouped) {
1111*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1112*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1113*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1114*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1115*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1116*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
1117*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1118*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1119*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1120*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1121*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1122*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1123*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1124*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1125*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1126*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1127*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
1128*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1129*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1130*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1131*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1132*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1133*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1134*4bdc9457SAndroid Build Coastguard Worker }
1135*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_height_depthwise)1136*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_height_depthwise) {
1137*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1138*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1139*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1140*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1141*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1142*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
1143*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1144*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1145*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1146*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1147*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1148*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1149*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1150*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1151*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1152*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1153*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
1154*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1155*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1156*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1157*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1158*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1159*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1160*4bdc9457SAndroid Build Coastguard Worker }
1161*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_width)1162*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_width) {
1163*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1164*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1165*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1166*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1167*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1168*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1169*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1170*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1171*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1172*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1173*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1174*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1175*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1176*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1177*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1178*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
1179*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1180*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1181*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1182*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1183*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1184*4bdc9457SAndroid Build Coastguard Worker }
1185*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_width_grouped)1186*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_width_grouped) {
1187*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1188*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1189*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1190*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1191*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1192*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1193*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1194*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1195*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1196*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1197*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1198*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1199*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1200*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1201*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1202*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1203*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
1204*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1205*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1206*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1207*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1208*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1209*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1210*4bdc9457SAndroid Build Coastguard Worker }
1211*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_changing_width_depthwise)1212*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_changing_width_depthwise) {
1213*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1214*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1215*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1216*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1217*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1218*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1219*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1220*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1221*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1222*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1223*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1224*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1225*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1226*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1227*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
1228*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1229*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
1230*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1231*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1232*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1233*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1234*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1235*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1236*4bdc9457SAndroid Build Coastguard Worker }
1237*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_swap_height_and_width)1238*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_swap_height_and_width) {
1239*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1240*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1241*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1242*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
1243*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1244*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
1245*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1246*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1247*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1248*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1249*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1250*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1251*4bdc9457SAndroid Build Coastguard Worker }
1252*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_swap_height_and_width_grouped)1253*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_swap_height_and_width_grouped) {
1254*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1255*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1256*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1257*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
1258*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1259*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
1260*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1261*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
1262*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1263*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1264*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1265*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1266*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1267*4bdc9457SAndroid Build Coastguard Worker }
1268*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QC8,setup_swap_height_and_width_depthwise)1269*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QC8, setup_swap_height_and_width_depthwise) {
1270*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
1271*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1272*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1273*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
1274*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
1275*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
1276*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
1277*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
1278*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
1279*4bdc9457SAndroid Build Coastguard Worker .groups(19)
1280*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
1281*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
1282*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQC8();
1283*4bdc9457SAndroid Build Coastguard Worker }
1284*4bdc9457SAndroid Build Coastguard Worker
1285*4bdc9457SAndroid Build Coastguard Worker
1286*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1) {
1287*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1288*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1289*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1290*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1291*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1292*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1293*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1294*4bdc9457SAndroid Build Coastguard Worker }
1295*4bdc9457SAndroid Build Coastguard Worker
1296*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_with_qmin) {
1297*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1298*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1299*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1300*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1301*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1302*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1303*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1304*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1305*4bdc9457SAndroid Build Coastguard Worker }
1306*4bdc9457SAndroid Build Coastguard Worker
1307*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_with_qmax) {
1308*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1309*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1310*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1311*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1312*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1313*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1314*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1315*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1316*4bdc9457SAndroid Build Coastguard Worker }
1317*4bdc9457SAndroid Build Coastguard Worker
1318*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_with_input_stride) {
1319*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1320*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1321*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1322*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
1323*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1324*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1325*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1326*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1327*4bdc9457SAndroid Build Coastguard Worker }
1328*4bdc9457SAndroid Build Coastguard Worker
1329*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_with_output_stride) {
1330*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1331*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1332*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1333*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
1334*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1335*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1336*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1337*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1338*4bdc9457SAndroid Build Coastguard Worker }
1339*4bdc9457SAndroid Build Coastguard Worker
1340*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_without_bias) {
1341*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1342*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
1343*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
1344*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1345*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1346*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1347*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1348*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1349*4bdc9457SAndroid Build Coastguard Worker }
1350*4bdc9457SAndroid Build Coastguard Worker
1351*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x1_with_batch) {
1352*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1353*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1354*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
1355*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1356*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1357*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1358*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1359*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1360*4bdc9457SAndroid Build Coastguard Worker }
1361*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1)1362*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1) {
1363*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1364*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1365*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1366*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1367*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1368*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1369*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1370*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1371*4bdc9457SAndroid Build Coastguard Worker }
1372*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_with_qmin)1373*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_with_qmin) {
1374*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1375*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1376*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1377*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1378*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1379*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1380*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1381*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1382*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1383*4bdc9457SAndroid Build Coastguard Worker }
1384*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_with_qmax)1385*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_with_qmax) {
1386*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1387*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1388*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1389*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1390*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1391*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1392*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1393*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1394*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1395*4bdc9457SAndroid Build Coastguard Worker }
1396*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_with_input_stride)1397*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_with_input_stride) {
1398*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1399*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1400*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1401*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1402*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
1403*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1404*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1405*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1406*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1407*4bdc9457SAndroid Build Coastguard Worker }
1408*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_with_output_stride)1409*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_with_output_stride) {
1410*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1411*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1412*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1413*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1414*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
1415*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1416*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1417*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1418*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1419*4bdc9457SAndroid Build Coastguard Worker }
1420*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_without_bias)1421*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_without_bias) {
1422*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1423*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
1424*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1425*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1426*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1427*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1428*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1429*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1430*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1431*4bdc9457SAndroid Build Coastguard Worker }
1432*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x1_with_batch)1433*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x1_with_batch) {
1434*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1435*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1436*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
1437*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1438*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1439*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1440*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1441*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1442*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1443*4bdc9457SAndroid Build Coastguard Worker }
1444*4bdc9457SAndroid Build Coastguard Worker
1445*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 1x3) {
1446*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1447*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
1448*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
1449*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
1450*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1451*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
1452*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1453*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1454*4bdc9457SAndroid Build Coastguard Worker }
1455*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_1x3)1456*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_1x3) {
1457*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1458*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
1459*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
1460*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
1461*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1462*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1463*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
1464*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1465*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1466*4bdc9457SAndroid Build Coastguard Worker }
1467*4bdc9457SAndroid Build Coastguard Worker
1468*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x1) {
1469*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1470*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
1471*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
1472*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
1473*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1474*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
1475*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1476*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1477*4bdc9457SAndroid Build Coastguard Worker }
1478*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x1)1479*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x1) {
1480*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1481*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
1482*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
1483*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
1484*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1485*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
1486*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
1487*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1488*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1489*4bdc9457SAndroid Build Coastguard Worker }
1490*4bdc9457SAndroid Build Coastguard Worker
1491*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3) {
1492*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1493*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1494*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1495*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1496*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1497*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1498*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1499*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1500*4bdc9457SAndroid Build Coastguard Worker }
1501*4bdc9457SAndroid Build Coastguard Worker
1502*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_without_padding) {
1503*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1504*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1505*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1506*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1507*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1508*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1509*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1510*4bdc9457SAndroid Build Coastguard Worker }
1511*4bdc9457SAndroid Build Coastguard Worker
1512*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_left_padding) {
1513*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1514*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1515*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1516*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1517*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1518*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1519*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1520*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1521*4bdc9457SAndroid Build Coastguard Worker }
1522*4bdc9457SAndroid Build Coastguard Worker
1523*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_right_padding) {
1524*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1525*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1526*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1527*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1528*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1529*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1530*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1531*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1532*4bdc9457SAndroid Build Coastguard Worker }
1533*4bdc9457SAndroid Build Coastguard Worker
1534*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_top_padding) {
1535*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1536*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1537*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1538*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1539*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1540*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1541*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1542*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1543*4bdc9457SAndroid Build Coastguard Worker }
1544*4bdc9457SAndroid Build Coastguard Worker
1545*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_bottom_padding) {
1546*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1547*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1548*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1549*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1550*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1551*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1552*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1553*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1554*4bdc9457SAndroid Build Coastguard Worker }
1555*4bdc9457SAndroid Build Coastguard Worker
1556*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_input_stride) {
1557*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1558*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1559*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1560*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1561*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
1562*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1563*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1564*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1565*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1566*4bdc9457SAndroid Build Coastguard Worker }
1567*4bdc9457SAndroid Build Coastguard Worker
1568*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_output_stride) {
1569*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1570*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1571*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1572*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1573*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
1574*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1575*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1576*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1577*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1578*4bdc9457SAndroid Build Coastguard Worker }
1579*4bdc9457SAndroid Build Coastguard Worker
1580*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_without_bias) {
1581*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1582*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
1583*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
1584*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1585*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1586*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1587*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1588*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1589*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1590*4bdc9457SAndroid Build Coastguard Worker }
1591*4bdc9457SAndroid Build Coastguard Worker
1592*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3_with_batch) {
1593*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1594*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1595*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
1596*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1597*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1598*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1599*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1600*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1601*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1602*4bdc9457SAndroid Build Coastguard Worker }
1603*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3)1604*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3) {
1605*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1606*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1607*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1608*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1609*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1610*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1611*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1612*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1613*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1614*4bdc9457SAndroid Build Coastguard Worker }
1615*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_without_padding)1616*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_without_padding) {
1617*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1618*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1619*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1620*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1621*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1622*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1623*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1624*4bdc9457SAndroid Build Coastguard Worker }
1625*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_left_padding)1626*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_left_padding) {
1627*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1628*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1629*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
1630*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1631*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1632*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1633*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1634*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1635*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1636*4bdc9457SAndroid Build Coastguard Worker }
1637*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_right_padding)1638*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_right_padding) {
1639*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1640*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1641*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
1642*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1643*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1644*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1645*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1646*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1647*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1648*4bdc9457SAndroid Build Coastguard Worker }
1649*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_top_padding)1650*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_top_padding) {
1651*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1652*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1653*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
1654*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1655*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1656*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1657*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1658*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1659*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1660*4bdc9457SAndroid Build Coastguard Worker }
1661*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_bottom_padding)1662*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_bottom_padding) {
1663*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1664*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1665*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
1666*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1667*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1668*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1669*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1670*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1671*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1672*4bdc9457SAndroid Build Coastguard Worker }
1673*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_input_stride)1674*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_input_stride) {
1675*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1676*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1677*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1678*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1679*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1680*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
1681*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1682*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1683*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1684*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1685*4bdc9457SAndroid Build Coastguard Worker }
1686*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_output_stride)1687*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_output_stride) {
1688*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1689*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1690*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1691*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1692*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1693*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
1694*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1695*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1696*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1697*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1698*4bdc9457SAndroid Build Coastguard Worker }
1699*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_without_bias)1700*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_without_bias) {
1701*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1702*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
1703*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1704*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1705*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1706*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1707*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1708*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1709*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1710*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1711*4bdc9457SAndroid Build Coastguard Worker }
1712*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,grouped_3x3_with_batch)1713*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, grouped_3x3_with_batch) {
1714*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1715*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
1716*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
1717*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1718*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1719*4bdc9457SAndroid Build Coastguard Worker .groups(2)
1720*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
1721*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
1722*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1723*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1724*4bdc9457SAndroid Build Coastguard Worker }
1725*4bdc9457SAndroid Build Coastguard Worker
1726*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s2) {
1727*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1728*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1729*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1730*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1731*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
1732*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1733*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1734*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1735*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1736*4bdc9457SAndroid Build Coastguard Worker }
1737*4bdc9457SAndroid Build Coastguard Worker
1738*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s2_with_tf_same_padding) {
1739*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
1740*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
1741*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1742*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1743*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1744*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1745*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
1746*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1747*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1748*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1749*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1750*4bdc9457SAndroid Build Coastguard Worker }
1751*4bdc9457SAndroid Build Coastguard Worker }
1752*4bdc9457SAndroid Build Coastguard Worker }
1753*4bdc9457SAndroid Build Coastguard Worker
1754*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s1x2) {
1755*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1756*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1757*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1758*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1759*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
1760*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1761*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1762*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1763*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1764*4bdc9457SAndroid Build Coastguard Worker }
1765*4bdc9457SAndroid Build Coastguard Worker
1766*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s1x2_with_tf_same_padding) {
1767*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
1768*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
1769*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1770*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1771*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1772*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1773*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
1774*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1775*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1776*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1777*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1778*4bdc9457SAndroid Build Coastguard Worker }
1779*4bdc9457SAndroid Build Coastguard Worker }
1780*4bdc9457SAndroid Build Coastguard Worker }
1781*4bdc9457SAndroid Build Coastguard Worker
1782*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s2x1) {
1783*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1784*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1785*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1786*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1787*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
1788*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1789*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1790*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1791*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1792*4bdc9457SAndroid Build Coastguard Worker }
1793*4bdc9457SAndroid Build Coastguard Worker
1794*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3s2x1_with_tf_same_padding) {
1795*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
1796*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
1797*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1798*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1799*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1800*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1801*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
1802*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1803*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1804*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1805*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1806*4bdc9457SAndroid Build Coastguard Worker }
1807*4bdc9457SAndroid Build Coastguard Worker }
1808*4bdc9457SAndroid Build Coastguard Worker }
1809*4bdc9457SAndroid Build Coastguard Worker
1810*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3d2) {
1811*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1812*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1813*4bdc9457SAndroid Build Coastguard Worker .padding(2)
1814*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1815*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
1816*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1817*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1818*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1819*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1820*4bdc9457SAndroid Build Coastguard Worker }
1821*4bdc9457SAndroid Build Coastguard Worker
1822*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3d1x2) {
1823*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1824*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1825*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
1826*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1827*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
1828*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1829*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1830*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1831*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1832*4bdc9457SAndroid Build Coastguard Worker }
1833*4bdc9457SAndroid Build Coastguard Worker
1834*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, 3x3d2x1) {
1835*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1836*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
1837*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
1838*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1839*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
1840*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
1841*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1842*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1843*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1844*4bdc9457SAndroid Build Coastguard Worker }
1845*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3)1846*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3) {
1847*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1848*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1849*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1850*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1851*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1852*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1853*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1854*4bdc9457SAndroid Build Coastguard Worker }
1855*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3_without_bias)1856*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3_without_bias) {
1857*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1858*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
1859*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1860*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1861*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1862*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1863*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1864*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1865*4bdc9457SAndroid Build Coastguard Worker }
1866*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s2)1867*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s2) {
1868*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1869*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1870*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1871*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1872*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
1873*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1874*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1875*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1876*4bdc9457SAndroid Build Coastguard Worker }
1877*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s2_with_tf_same_padding)1878*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s2_with_tf_same_padding) {
1879*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
1880*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
1881*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1882*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1883*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1884*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1885*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
1886*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1887*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1888*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1889*4bdc9457SAndroid Build Coastguard Worker }
1890*4bdc9457SAndroid Build Coastguard Worker }
1891*4bdc9457SAndroid Build Coastguard Worker }
1892*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s1x2)1893*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s1x2) {
1894*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1895*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1896*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1897*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1898*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
1899*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1900*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1901*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1902*4bdc9457SAndroid Build Coastguard Worker }
1903*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s1x2_with_tf_same_padding)1904*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s1x2_with_tf_same_padding) {
1905*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
1906*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
1907*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1908*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1909*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1910*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1911*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
1912*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1913*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1914*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1915*4bdc9457SAndroid Build Coastguard Worker }
1916*4bdc9457SAndroid Build Coastguard Worker }
1917*4bdc9457SAndroid Build Coastguard Worker }
1918*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s2x1)1919*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s2x1) {
1920*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1921*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1922*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1923*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1924*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
1925*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1926*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1927*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1928*4bdc9457SAndroid Build Coastguard Worker }
1929*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3s2x1_with_tf_same_padding)1930*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3s2x1_with_tf_same_padding) {
1931*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
1932*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
1933*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1934*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
1935*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
1936*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1937*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
1938*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1939*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1940*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1941*4bdc9457SAndroid Build Coastguard Worker }
1942*4bdc9457SAndroid Build Coastguard Worker }
1943*4bdc9457SAndroid Build Coastguard Worker }
1944*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3d2)1945*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3d2) {
1946*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1947*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1948*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1949*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1950*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
1951*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1952*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1953*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1954*4bdc9457SAndroid Build Coastguard Worker }
1955*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3d1x2)1956*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3d1x2) {
1957*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1958*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1959*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1960*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1961*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
1962*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1963*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1964*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1965*4bdc9457SAndroid Build Coastguard Worker }
1966*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,depthwise_3x3d2x1)1967*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, depthwise_3x3d2x1) {
1968*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1969*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
1970*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
1971*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1972*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
1973*4bdc9457SAndroid Build Coastguard Worker .groups(27)
1974*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1975*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1976*4bdc9457SAndroid Build Coastguard Worker }
1977*4bdc9457SAndroid Build Coastguard Worker
1978*4bdc9457SAndroid Build Coastguard Worker // Tests GEMM microkernel with weights_cache.
TEST(CONVOLUTION_NHWC_QS8,weights_cache_1x1)1979*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, weights_cache_1x1) {
1980*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1981*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
1982*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
1983*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
1984*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
1985*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
1986*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
1987*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
1988*4bdc9457SAndroid Build Coastguard Worker }
1989*4bdc9457SAndroid Build Coastguard Worker
1990*4bdc9457SAndroid Build Coastguard Worker // Tests IGEMM microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QS8,weights_cache_3x3)1991*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, weights_cache_3x3) {
1992*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
1993*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
1994*4bdc9457SAndroid Build Coastguard Worker .padding(1)
1995*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
1996*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
1997*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
1998*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
1999*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2000*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2001*4bdc9457SAndroid Build Coastguard Worker }
2002*4bdc9457SAndroid Build Coastguard Worker
2003*4bdc9457SAndroid Build Coastguard Worker // Tests vmulcaddc microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QS8,weights_cache_depthwise_1x1)2004*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, weights_cache_depthwise_1x1) {
2005*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2006*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2007*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2008*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2009*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
2010*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2011*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2012*4bdc9457SAndroid Build Coastguard Worker }
2013*4bdc9457SAndroid Build Coastguard Worker
2014*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QS8,weights_cache_depthwise_2x2d2)2015*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, weights_cache_depthwise_2x2d2) {
2016*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2017*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2018*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2019*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
2020*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
2021*4bdc9457SAndroid Build Coastguard Worker .groups(27)
2022*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2023*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
2024*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2025*4bdc9457SAndroid Build Coastguard Worker }
2026*4bdc9457SAndroid Build Coastguard Worker
2027*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 1x1) {
2028*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2029*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2030*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2031*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2032*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2033*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2034*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2035*4bdc9457SAndroid Build Coastguard Worker }
2036*4bdc9457SAndroid Build Coastguard Worker
2037*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 1x1_with_depth_multiplier) {
2038*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2039*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2040*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2041*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2042*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2043*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
2044*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2045*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2046*4bdc9457SAndroid Build Coastguard Worker }
2047*4bdc9457SAndroid Build Coastguard Worker
2048*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 1x1_without_bias) {
2049*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2050*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2051*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2052*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2053*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2054*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2055*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2056*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2057*4bdc9457SAndroid Build Coastguard Worker }
2058*4bdc9457SAndroid Build Coastguard Worker
2059*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 2x2) {
2060*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2061*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2062*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2063*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2064*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
2065*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2066*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2067*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2068*4bdc9457SAndroid Build Coastguard Worker }
2069*4bdc9457SAndroid Build Coastguard Worker
2070*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 2x2_with_depth_multiplier) {
2071*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2072*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2073*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2074*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2075*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
2076*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2077*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
2078*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2079*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2080*4bdc9457SAndroid Build Coastguard Worker }
2081*4bdc9457SAndroid Build Coastguard Worker
2082*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 2x2_without_bias) {
2083*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2084*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2085*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2086*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2087*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2088*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
2089*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2090*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2091*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2092*4bdc9457SAndroid Build Coastguard Worker }
2093*4bdc9457SAndroid Build Coastguard Worker
2094*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 3x3) {
2095*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2096*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2097*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2098*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2099*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2100*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2101*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2102*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2103*4bdc9457SAndroid Build Coastguard Worker }
2104*4bdc9457SAndroid Build Coastguard Worker
2105*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 3x3_with_depth_multiplier) {
2106*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2107*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2108*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2109*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2110*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2111*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2112*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
2113*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2114*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2115*4bdc9457SAndroid Build Coastguard Worker }
2116*4bdc9457SAndroid Build Coastguard Worker
2117*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 3x3_without_bias) {
2118*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2119*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2120*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2121*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2122*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2123*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2124*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2125*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2126*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2127*4bdc9457SAndroid Build Coastguard Worker }
2128*4bdc9457SAndroid Build Coastguard Worker
2129*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 3x3s2_with_tf_same_padding) {
2130*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
2131*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
2132*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2133*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2134*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
2135*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
2136*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2137*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2138*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2139*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2140*4bdc9457SAndroid Build Coastguard Worker }
2141*4bdc9457SAndroid Build Coastguard Worker }
2142*4bdc9457SAndroid Build Coastguard Worker }
2143*4bdc9457SAndroid Build Coastguard Worker
2144*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 5x5) {
2145*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2146*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2147*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2148*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
2149*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
2150*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2151*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2152*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2153*4bdc9457SAndroid Build Coastguard Worker }
2154*4bdc9457SAndroid Build Coastguard Worker
2155*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 5x5_with_depth_multiplier) {
2156*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2157*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2158*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2159*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
2160*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
2161*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2162*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
2163*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2164*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2165*4bdc9457SAndroid Build Coastguard Worker }
2166*4bdc9457SAndroid Build Coastguard Worker
2167*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 5x5_without_bias) {
2168*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2169*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2170*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2171*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2172*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
2173*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
2174*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2175*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2176*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2177*4bdc9457SAndroid Build Coastguard Worker }
2178*4bdc9457SAndroid Build Coastguard Worker
2179*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 7x7) {
2180*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2181*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2182*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2183*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
2184*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
2185*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2186*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2187*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2188*4bdc9457SAndroid Build Coastguard Worker }
2189*4bdc9457SAndroid Build Coastguard Worker
2190*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, 7x7_without_bias) {
2191*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2192*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2193*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2194*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2195*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
2196*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
2197*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2198*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2199*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2200*4bdc9457SAndroid Build Coastguard Worker }
2201*4bdc9457SAndroid Build Coastguard Worker
2202*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8,weights_cache_1x1)2203*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, weights_cache_1x1) {
2204*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2205*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2206*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2207*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2208*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2209*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
2210*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2211*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2212*4bdc9457SAndroid Build Coastguard Worker }
2213*4bdc9457SAndroid Build Coastguard Worker
2214*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernek with non 1x1 kernel (dwconv_hwg packing).
TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8,weights_cache_2x2)2215*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QS8, weights_cache_2x2) {
2216*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2217*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
2218*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
2219*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
2220*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
2221*4bdc9457SAndroid Build Coastguard Worker .groups(24)
2222*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
2223*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2224*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQS8();
2225*4bdc9457SAndroid Build Coastguard Worker }
2226*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_input_buffer)2227*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_input_buffer) {
2228*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2229*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2230*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2231*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2232*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2233*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2234*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2235*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2236*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2237*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2238*4bdc9457SAndroid Build Coastguard Worker }
2239*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_input_buffer_grouped)2240*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_input_buffer_grouped) {
2241*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2242*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2243*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2244*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2245*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2246*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2247*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2248*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2249*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2250*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2251*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2252*4bdc9457SAndroid Build Coastguard Worker }
2253*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_input_buffer_depthwise)2254*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_input_buffer_depthwise) {
2255*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2256*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2257*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2258*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2259*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2260*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2261*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2262*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2263*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2264*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2265*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2266*4bdc9457SAndroid Build Coastguard Worker }
2267*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_increasing_batch)2268*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_increasing_batch) {
2269*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2270*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2271*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2272*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
2273*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2274*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2275*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2276*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2277*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2278*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2279*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2280*4bdc9457SAndroid Build Coastguard Worker }
2281*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_increasing_batch_grouped)2282*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_increasing_batch_grouped) {
2283*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2284*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2285*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2286*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
2287*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2288*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2289*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2290*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2291*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2292*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2293*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2294*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2295*4bdc9457SAndroid Build Coastguard Worker }
2296*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_increasing_batch_depthwise)2297*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_increasing_batch_depthwise) {
2298*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2299*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2300*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2301*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
2302*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2303*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2304*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2305*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2306*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2307*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2308*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2309*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2310*4bdc9457SAndroid Build Coastguard Worker }
2311*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_decreasing_batch)2312*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_decreasing_batch) {
2313*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2314*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2315*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
2316*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
2317*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2318*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2319*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2320*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2321*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2322*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2323*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2324*4bdc9457SAndroid Build Coastguard Worker }
2325*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_decreasing_batch_grouped)2326*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_decreasing_batch_grouped) {
2327*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2328*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2329*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
2330*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
2331*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2332*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2333*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2334*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2335*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2336*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2337*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2338*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2339*4bdc9457SAndroid Build Coastguard Worker }
2340*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_decreasing_batch_depthwise)2341*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_decreasing_batch_depthwise) {
2342*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2343*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2344*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
2345*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
2346*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2347*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2348*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2349*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2350*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2351*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2352*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2353*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2354*4bdc9457SAndroid Build Coastguard Worker }
2355*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_height)2356*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_height) {
2357*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2358*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2359*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2360*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2361*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2362*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
2363*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2364*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2365*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2366*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2367*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2368*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2369*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2370*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2371*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2372*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
2373*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2374*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2375*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2376*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2377*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2378*4bdc9457SAndroid Build Coastguard Worker }
2379*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_height_grouped)2380*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_height_grouped) {
2381*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2382*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2383*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2384*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2385*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2386*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
2387*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2388*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2389*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2390*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2391*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2392*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2393*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2394*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2395*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2396*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2397*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
2398*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2399*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2400*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2401*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2402*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2403*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2404*4bdc9457SAndroid Build Coastguard Worker }
2405*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_height_depthwise)2406*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_height_depthwise) {
2407*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2408*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2409*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2410*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2411*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2412*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
2413*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2414*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2415*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2416*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2417*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2418*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2419*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2420*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2421*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2422*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2423*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
2424*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2425*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2426*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2427*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2428*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2429*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2430*4bdc9457SAndroid Build Coastguard Worker }
2431*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_width)2432*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_width) {
2433*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2434*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2435*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2436*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2437*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2438*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2439*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2440*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2441*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2442*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2443*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2444*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2445*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2446*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2447*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2448*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
2449*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2450*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2451*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2452*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2453*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2454*4bdc9457SAndroid Build Coastguard Worker }
2455*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_width_grouped)2456*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_width_grouped) {
2457*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2458*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2459*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2460*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2461*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2462*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2463*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2464*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2465*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2466*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2467*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2468*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2469*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2470*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2471*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2472*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2473*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
2474*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2475*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2476*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2477*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2478*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2479*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2480*4bdc9457SAndroid Build Coastguard Worker }
2481*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_changing_width_depthwise)2482*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_changing_width_depthwise) {
2483*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2484*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2485*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2486*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2487*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2488*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2489*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2490*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2491*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2492*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2493*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2494*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2495*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2496*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2497*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
2498*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2499*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
2500*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2501*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2502*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2503*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2504*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2505*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2506*4bdc9457SAndroid Build Coastguard Worker }
2507*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_swap_height_and_width)2508*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_swap_height_and_width) {
2509*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2510*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2511*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2512*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
2513*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2514*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
2515*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2516*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2517*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2518*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2519*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2520*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2521*4bdc9457SAndroid Build Coastguard Worker }
2522*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_swap_height_and_width_grouped)2523*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_swap_height_and_width_grouped) {
2524*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2525*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2526*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2527*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
2528*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2529*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
2530*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2531*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
2532*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2533*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2534*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2535*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2536*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2537*4bdc9457SAndroid Build Coastguard Worker }
2538*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QS8,setup_swap_height_and_width_depthwise)2539*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QS8, setup_swap_height_and_width_depthwise) {
2540*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
2541*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2542*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2543*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
2544*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
2545*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
2546*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
2547*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
2548*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
2549*4bdc9457SAndroid Build Coastguard Worker .groups(19)
2550*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
2551*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
2552*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQS8();
2553*4bdc9457SAndroid Build Coastguard Worker }
2554*4bdc9457SAndroid Build Coastguard Worker
2555*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1) {
2556*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2557*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
2558*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2559*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2560*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2561*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2562*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2563*4bdc9457SAndroid Build Coastguard Worker }
2564*4bdc9457SAndroid Build Coastguard Worker
2565*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_with_qmin) {
2566*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2567*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
2568*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2569*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2570*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2571*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2572*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2573*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2574*4bdc9457SAndroid Build Coastguard Worker }
2575*4bdc9457SAndroid Build Coastguard Worker
2576*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_with_qmax) {
2577*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2578*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
2579*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2580*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2581*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2582*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2583*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2584*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2585*4bdc9457SAndroid Build Coastguard Worker }
2586*4bdc9457SAndroid Build Coastguard Worker
2587*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_with_input_stride) {
2588*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2589*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
2590*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2591*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
2592*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2593*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2594*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2595*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2596*4bdc9457SAndroid Build Coastguard Worker }
2597*4bdc9457SAndroid Build Coastguard Worker
2598*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_with_output_stride) {
2599*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2600*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
2601*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2602*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
2603*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2604*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2605*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2606*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2607*4bdc9457SAndroid Build Coastguard Worker }
2608*4bdc9457SAndroid Build Coastguard Worker
2609*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_without_bias) {
2610*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2611*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2612*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
2613*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2614*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2615*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2616*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2617*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2618*4bdc9457SAndroid Build Coastguard Worker }
2619*4bdc9457SAndroid Build Coastguard Worker
2620*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x1_with_batch) {
2621*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2622*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2623*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
2624*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2625*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
2626*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2627*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2628*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2629*4bdc9457SAndroid Build Coastguard Worker }
2630*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1)2631*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1) {
2632*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2633*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2634*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2635*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2636*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2637*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2638*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2639*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2640*4bdc9457SAndroid Build Coastguard Worker }
2641*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_with_qmin)2642*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_with_qmin) {
2643*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2644*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2645*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2646*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2647*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2648*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2649*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2650*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2651*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2652*4bdc9457SAndroid Build Coastguard Worker }
2653*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_with_qmax)2654*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_with_qmax) {
2655*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2656*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2657*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2658*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2659*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2660*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2661*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2662*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2663*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2664*4bdc9457SAndroid Build Coastguard Worker }
2665*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_with_input_stride)2666*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_with_input_stride) {
2667*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2668*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2669*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2670*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2671*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
2672*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2673*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2674*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2675*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2676*4bdc9457SAndroid Build Coastguard Worker }
2677*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_with_output_stride)2678*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_with_output_stride) {
2679*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2680*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2681*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2682*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2683*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
2684*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2685*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2686*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2687*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2688*4bdc9457SAndroid Build Coastguard Worker }
2689*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_without_bias)2690*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_without_bias) {
2691*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2692*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2693*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2694*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2695*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2696*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2697*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2698*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2699*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2700*4bdc9457SAndroid Build Coastguard Worker }
2701*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x1_with_batch)2702*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x1_with_batch) {
2703*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2704*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2705*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
2706*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
2707*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2708*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2709*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
2710*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2711*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2712*4bdc9457SAndroid Build Coastguard Worker }
2713*4bdc9457SAndroid Build Coastguard Worker
2714*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 1x3) {
2715*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2716*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
2717*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
2718*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
2719*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2720*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
2721*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2722*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2723*4bdc9457SAndroid Build Coastguard Worker }
2724*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_1x3)2725*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_1x3) {
2726*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2727*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
2728*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
2729*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
2730*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2731*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2732*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
2733*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2734*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2735*4bdc9457SAndroid Build Coastguard Worker }
2736*4bdc9457SAndroid Build Coastguard Worker
2737*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x1) {
2738*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2739*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
2740*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
2741*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
2742*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2743*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
2744*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2745*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2746*4bdc9457SAndroid Build Coastguard Worker }
2747*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x1)2748*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x1) {
2749*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2750*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
2751*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
2752*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
2753*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2754*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
2755*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
2756*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2757*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2758*4bdc9457SAndroid Build Coastguard Worker }
2759*4bdc9457SAndroid Build Coastguard Worker
2760*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3) {
2761*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2762*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2763*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2764*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2765*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2766*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2767*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2768*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2769*4bdc9457SAndroid Build Coastguard Worker }
2770*4bdc9457SAndroid Build Coastguard Worker
2771*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_without_padding) {
2772*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2773*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2774*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2775*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2776*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2777*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2778*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2779*4bdc9457SAndroid Build Coastguard Worker }
2780*4bdc9457SAndroid Build Coastguard Worker
2781*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_left_padding) {
2782*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2783*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2784*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
2785*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2786*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2787*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2788*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2789*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2790*4bdc9457SAndroid Build Coastguard Worker }
2791*4bdc9457SAndroid Build Coastguard Worker
2792*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_right_padding) {
2793*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2794*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2795*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
2796*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2797*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2798*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2799*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2800*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2801*4bdc9457SAndroid Build Coastguard Worker }
2802*4bdc9457SAndroid Build Coastguard Worker
2803*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_top_padding) {
2804*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2805*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2806*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
2807*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2808*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2809*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2810*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2811*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2812*4bdc9457SAndroid Build Coastguard Worker }
2813*4bdc9457SAndroid Build Coastguard Worker
2814*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_bottom_padding) {
2815*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2816*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2817*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
2818*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2819*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2820*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2821*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2822*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2823*4bdc9457SAndroid Build Coastguard Worker }
2824*4bdc9457SAndroid Build Coastguard Worker
2825*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_input_stride) {
2826*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2827*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2828*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2829*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2830*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
2831*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2832*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2833*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2834*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2835*4bdc9457SAndroid Build Coastguard Worker }
2836*4bdc9457SAndroid Build Coastguard Worker
2837*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_output_stride) {
2838*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2839*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2840*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2841*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2842*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
2843*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2844*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2845*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2846*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2847*4bdc9457SAndroid Build Coastguard Worker }
2848*4bdc9457SAndroid Build Coastguard Worker
2849*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_without_bias) {
2850*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2851*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2852*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
2853*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2854*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2855*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2856*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2857*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2858*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2859*4bdc9457SAndroid Build Coastguard Worker }
2860*4bdc9457SAndroid Build Coastguard Worker
2861*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3_with_batch) {
2862*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2863*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2864*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
2865*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2866*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2867*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2868*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2869*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2870*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2871*4bdc9457SAndroid Build Coastguard Worker }
2872*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3)2873*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3) {
2874*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2875*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2876*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2877*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2878*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2879*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2880*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2881*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2882*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2883*4bdc9457SAndroid Build Coastguard Worker }
2884*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_without_padding)2885*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_without_padding) {
2886*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2887*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
2888*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2889*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
2890*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
2891*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2892*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2893*4bdc9457SAndroid Build Coastguard Worker }
2894*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_left_padding)2895*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_left_padding) {
2896*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2897*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2898*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
2899*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2900*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2901*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2902*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2903*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2904*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2905*4bdc9457SAndroid Build Coastguard Worker }
2906*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_right_padding)2907*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_right_padding) {
2908*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2909*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2910*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
2911*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2912*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2913*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2914*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2915*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2916*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2917*4bdc9457SAndroid Build Coastguard Worker }
2918*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_top_padding)2919*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_top_padding) {
2920*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2921*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2922*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
2923*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2924*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2925*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2926*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2927*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2928*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2929*4bdc9457SAndroid Build Coastguard Worker }
2930*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_bottom_padding)2931*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_bottom_padding) {
2932*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2933*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2934*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
2935*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2936*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2937*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2938*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2939*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2940*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2941*4bdc9457SAndroid Build Coastguard Worker }
2942*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_input_stride)2943*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_input_stride) {
2944*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2945*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2946*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2947*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2948*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2949*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
2950*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2951*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2952*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2953*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2954*4bdc9457SAndroid Build Coastguard Worker }
2955*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_output_stride)2956*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_output_stride) {
2957*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2958*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2959*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2960*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2961*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2962*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
2963*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2964*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2965*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2966*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2967*4bdc9457SAndroid Build Coastguard Worker }
2968*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_without_bias)2969*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_without_bias) {
2970*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2971*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
2972*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2973*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2974*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2975*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2976*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2977*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2978*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2979*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2980*4bdc9457SAndroid Build Coastguard Worker }
2981*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,grouped_3x3_with_batch)2982*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, grouped_3x3_with_batch) {
2983*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2984*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
2985*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
2986*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2987*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
2988*4bdc9457SAndroid Build Coastguard Worker .groups(2)
2989*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
2990*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
2991*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
2992*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
2993*4bdc9457SAndroid Build Coastguard Worker }
2994*4bdc9457SAndroid Build Coastguard Worker
2995*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s2) {
2996*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
2997*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
2998*4bdc9457SAndroid Build Coastguard Worker .padding(1)
2999*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3000*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
3001*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3002*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3003*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3004*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3005*4bdc9457SAndroid Build Coastguard Worker }
3006*4bdc9457SAndroid Build Coastguard Worker
3007*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s2_with_tf_same_padding) {
3008*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
3009*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
3010*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3011*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3012*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3013*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3014*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
3015*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3016*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3017*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3018*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3019*4bdc9457SAndroid Build Coastguard Worker }
3020*4bdc9457SAndroid Build Coastguard Worker }
3021*4bdc9457SAndroid Build Coastguard Worker }
3022*4bdc9457SAndroid Build Coastguard Worker
3023*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s1x2) {
3024*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3025*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
3026*4bdc9457SAndroid Build Coastguard Worker .padding(1)
3027*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3028*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
3029*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3030*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3031*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3032*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3033*4bdc9457SAndroid Build Coastguard Worker }
3034*4bdc9457SAndroid Build Coastguard Worker
3035*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s1x2_with_tf_same_padding) {
3036*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
3037*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
3038*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3039*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3040*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3041*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3042*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
3043*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3044*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3045*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3046*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3047*4bdc9457SAndroid Build Coastguard Worker }
3048*4bdc9457SAndroid Build Coastguard Worker }
3049*4bdc9457SAndroid Build Coastguard Worker }
3050*4bdc9457SAndroid Build Coastguard Worker
3051*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s2x1) {
3052*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3053*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
3054*4bdc9457SAndroid Build Coastguard Worker .padding(1)
3055*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3056*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
3057*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3058*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3059*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3060*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3061*4bdc9457SAndroid Build Coastguard Worker }
3062*4bdc9457SAndroid Build Coastguard Worker
3063*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3s2x1_with_tf_same_padding) {
3064*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
3065*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
3066*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3067*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3068*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3069*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3070*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
3071*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3072*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3073*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3074*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3075*4bdc9457SAndroid Build Coastguard Worker }
3076*4bdc9457SAndroid Build Coastguard Worker }
3077*4bdc9457SAndroid Build Coastguard Worker }
3078*4bdc9457SAndroid Build Coastguard Worker
3079*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3d2) {
3080*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3081*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
3082*4bdc9457SAndroid Build Coastguard Worker .padding(2)
3083*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3084*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
3085*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3086*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3087*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3088*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3089*4bdc9457SAndroid Build Coastguard Worker }
3090*4bdc9457SAndroid Build Coastguard Worker
3091*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3d1x2) {
3092*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3093*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
3094*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
3095*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3096*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
3097*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3098*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3099*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3100*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3101*4bdc9457SAndroid Build Coastguard Worker }
3102*4bdc9457SAndroid Build Coastguard Worker
3103*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, 3x3d2x1) {
3104*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3105*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
3106*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
3107*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3108*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
3109*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
3110*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3111*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3112*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3113*4bdc9457SAndroid Build Coastguard Worker }
3114*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3)3115*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3) {
3116*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3117*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3118*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3119*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3120*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3121*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3122*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3123*4bdc9457SAndroid Build Coastguard Worker }
3124*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3_without_bias)3125*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3_without_bias) {
3126*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3127*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3128*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3129*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3130*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3131*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3132*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3133*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3134*4bdc9457SAndroid Build Coastguard Worker }
3135*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s2)3136*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s2) {
3137*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3138*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3139*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3140*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3141*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
3142*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3143*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3144*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3145*4bdc9457SAndroid Build Coastguard Worker }
3146*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s2_with_tf_same_padding)3147*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s2_with_tf_same_padding) {
3148*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
3149*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
3150*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3151*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3152*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3153*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3154*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
3155*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3156*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3157*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3158*4bdc9457SAndroid Build Coastguard Worker }
3159*4bdc9457SAndroid Build Coastguard Worker }
3160*4bdc9457SAndroid Build Coastguard Worker }
3161*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s1x2)3162*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s1x2) {
3163*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3164*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3165*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3166*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3167*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
3168*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3169*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3170*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3171*4bdc9457SAndroid Build Coastguard Worker }
3172*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s1x2_with_tf_same_padding)3173*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s1x2_with_tf_same_padding) {
3174*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
3175*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
3176*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3177*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3178*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3179*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3180*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
3181*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3182*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3183*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3184*4bdc9457SAndroid Build Coastguard Worker }
3185*4bdc9457SAndroid Build Coastguard Worker }
3186*4bdc9457SAndroid Build Coastguard Worker }
3187*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s2x1)3188*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s2x1) {
3189*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3190*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3191*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3192*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3193*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
3194*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3195*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3196*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3197*4bdc9457SAndroid Build Coastguard Worker }
3198*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3s2x1_with_tf_same_padding)3199*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3s2x1_with_tf_same_padding) {
3200*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
3201*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
3202*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3203*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3204*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3205*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3206*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
3207*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3208*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3209*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3210*4bdc9457SAndroid Build Coastguard Worker }
3211*4bdc9457SAndroid Build Coastguard Worker }
3212*4bdc9457SAndroid Build Coastguard Worker }
3213*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3d2)3214*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3d2) {
3215*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3216*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3217*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3218*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3219*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
3220*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3221*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3222*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3223*4bdc9457SAndroid Build Coastguard Worker }
3224*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3d1x2)3225*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3d1x2) {
3226*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3227*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3228*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3229*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3230*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
3231*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3232*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3233*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3234*4bdc9457SAndroid Build Coastguard Worker }
3235*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,depthwise_3x3d2x1)3236*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, depthwise_3x3d2x1) {
3237*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3238*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3239*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3240*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3241*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
3242*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3243*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3244*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3245*4bdc9457SAndroid Build Coastguard Worker }
3246*4bdc9457SAndroid Build Coastguard Worker
3247*4bdc9457SAndroid Build Coastguard Worker // Tests GEMM microkernel with weights_cache.
TEST(CONVOLUTION_NHWC_QU8,weights_cache_1x1)3248*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, weights_cache_1x1) {
3249*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3250*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3251*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3252*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3253*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3254*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3255*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3256*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3257*4bdc9457SAndroid Build Coastguard Worker }
3258*4bdc9457SAndroid Build Coastguard Worker
3259*4bdc9457SAndroid Build Coastguard Worker // Tests IGEMM microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QU8,weights_cache_3x3)3260*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, weights_cache_3x3) {
3261*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3262*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
3263*4bdc9457SAndroid Build Coastguard Worker .padding(1)
3264*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3265*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3266*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3267*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3268*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3269*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3270*4bdc9457SAndroid Build Coastguard Worker }
3271*4bdc9457SAndroid Build Coastguard Worker
3272*4bdc9457SAndroid Build Coastguard Worker // Tests vmulcaddc microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QU8,weights_cache_depthwise_1x1)3273*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, weights_cache_depthwise_1x1) {
3274*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3275*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3276*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3277*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3278*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3279*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3280*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3281*4bdc9457SAndroid Build Coastguard Worker }
3282*4bdc9457SAndroid Build Coastguard Worker
3283*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(CONVOLUTION_NHWC_QU8,weights_cache_depthwise_2x2d2)3284*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, weights_cache_depthwise_2x2d2) {
3285*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3286*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3287*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3288*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
3289*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
3290*4bdc9457SAndroid Build Coastguard Worker .groups(27)
3291*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3292*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3293*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3294*4bdc9457SAndroid Build Coastguard Worker }
3295*4bdc9457SAndroid Build Coastguard Worker
3296*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 1x1) {
3297*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3298*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3299*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3300*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3301*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3302*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3303*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3304*4bdc9457SAndroid Build Coastguard Worker }
3305*4bdc9457SAndroid Build Coastguard Worker
3306*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 1x1_with_depth_multiplier) {
3307*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3308*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3309*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3310*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3311*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3312*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
3313*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3314*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3315*4bdc9457SAndroid Build Coastguard Worker }
3316*4bdc9457SAndroid Build Coastguard Worker
3317*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 1x1_without_bias) {
3318*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3319*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3320*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3321*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3322*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3323*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3324*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3325*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3326*4bdc9457SAndroid Build Coastguard Worker }
3327*4bdc9457SAndroid Build Coastguard Worker
3328*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 2x2) {
3329*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3330*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3331*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3332*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3333*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
3334*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3335*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3336*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3337*4bdc9457SAndroid Build Coastguard Worker }
3338*4bdc9457SAndroid Build Coastguard Worker
3339*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 2x2_with_depth_multiplier) {
3340*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3341*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3342*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3343*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3344*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
3345*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3346*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
3347*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3348*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3349*4bdc9457SAndroid Build Coastguard Worker }
3350*4bdc9457SAndroid Build Coastguard Worker
3351*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 2x2_without_bias) {
3352*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3353*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3354*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3355*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3356*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3357*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
3358*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3359*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3360*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3361*4bdc9457SAndroid Build Coastguard Worker }
3362*4bdc9457SAndroid Build Coastguard Worker
3363*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 3x3) {
3364*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3365*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3366*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3367*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3368*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3369*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3370*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3371*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3372*4bdc9457SAndroid Build Coastguard Worker }
3373*4bdc9457SAndroid Build Coastguard Worker
3374*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 3x3_with_depth_multiplier) {
3375*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3376*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3377*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3378*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3379*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3380*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3381*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
3382*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3383*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3384*4bdc9457SAndroid Build Coastguard Worker }
3385*4bdc9457SAndroid Build Coastguard Worker
3386*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 3x3_without_bias) {
3387*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3388*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3389*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3390*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3391*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3392*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3393*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3394*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3395*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3396*4bdc9457SAndroid Build Coastguard Worker }
3397*4bdc9457SAndroid Build Coastguard Worker
3398*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 3x3s2_with_tf_same_padding) {
3399*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
3400*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
3401*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3402*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3403*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
3404*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
3405*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
3406*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3407*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3408*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3409*4bdc9457SAndroid Build Coastguard Worker }
3410*4bdc9457SAndroid Build Coastguard Worker }
3411*4bdc9457SAndroid Build Coastguard Worker }
3412*4bdc9457SAndroid Build Coastguard Worker
3413*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 5x5) {
3414*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3415*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3416*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3417*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
3418*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
3419*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3420*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3421*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3422*4bdc9457SAndroid Build Coastguard Worker }
3423*4bdc9457SAndroid Build Coastguard Worker
3424*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 5x5_with_depth_multiplier) {
3425*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3426*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3427*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3428*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
3429*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
3430*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3431*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
3432*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3433*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3434*4bdc9457SAndroid Build Coastguard Worker }
3435*4bdc9457SAndroid Build Coastguard Worker
3436*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 5x5_without_bias) {
3437*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3438*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3439*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3440*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3441*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
3442*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
3443*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3444*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3445*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3446*4bdc9457SAndroid Build Coastguard Worker }
3447*4bdc9457SAndroid Build Coastguard Worker
3448*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 7x7) {
3449*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3450*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3451*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3452*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
3453*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
3454*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3455*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3456*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3457*4bdc9457SAndroid Build Coastguard Worker }
3458*4bdc9457SAndroid Build Coastguard Worker
3459*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, 7x7_without_bias) {
3460*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3461*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3462*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3463*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3464*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
3465*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
3466*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3467*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3468*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3469*4bdc9457SAndroid Build Coastguard Worker }
3470*4bdc9457SAndroid Build Coastguard Worker
3471*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8,weights_cache_1x1)3472*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, weights_cache_1x1) {
3473*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3474*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3475*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3476*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3477*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3478*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3479*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3480*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3481*4bdc9457SAndroid Build Coastguard Worker }
3482*4bdc9457SAndroid Build Coastguard Worker
3483*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernek with non 1x1 kernel (dwconv_hwg packing).
TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8,weights_cache_2x2)3484*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_QU8, weights_cache_2x2) {
3485*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3486*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
3487*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
3488*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
3489*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
3490*4bdc9457SAndroid Build Coastguard Worker .groups(24)
3491*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
3492*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3493*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxQU8();
3494*4bdc9457SAndroid Build Coastguard Worker }
3495*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_input_buffer)3496*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_input_buffer) {
3497*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3498*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3499*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3500*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3501*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3502*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3503*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3504*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3505*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3506*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3507*4bdc9457SAndroid Build Coastguard Worker }
3508*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_input_buffer_grouped)3509*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_input_buffer_grouped) {
3510*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3511*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3512*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3513*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3514*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3515*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3516*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3517*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3518*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3519*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3520*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3521*4bdc9457SAndroid Build Coastguard Worker }
3522*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_input_buffer_depthwise)3523*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_input_buffer_depthwise) {
3524*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3525*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3526*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3527*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3528*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3529*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3530*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3531*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3532*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3533*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3534*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3535*4bdc9457SAndroid Build Coastguard Worker }
3536*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_increasing_batch)3537*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_increasing_batch) {
3538*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3539*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3540*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3541*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
3542*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3543*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3544*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3545*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3546*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3547*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3548*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3549*4bdc9457SAndroid Build Coastguard Worker }
3550*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_increasing_batch_grouped)3551*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_increasing_batch_grouped) {
3552*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3553*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3554*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3555*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
3556*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3557*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3558*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3559*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3560*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3561*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3562*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3563*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3564*4bdc9457SAndroid Build Coastguard Worker }
3565*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_increasing_batch_depthwise)3566*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_increasing_batch_depthwise) {
3567*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3568*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3569*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3570*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
3571*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3572*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3573*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3574*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3575*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3576*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3577*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3578*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3579*4bdc9457SAndroid Build Coastguard Worker }
3580*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_decreasing_batch)3581*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_decreasing_batch) {
3582*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3583*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3584*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
3585*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
3586*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3587*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3588*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3589*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3590*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3591*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3592*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3593*4bdc9457SAndroid Build Coastguard Worker }
3594*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_decreasing_batch_grouped)3595*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_decreasing_batch_grouped) {
3596*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3597*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3598*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
3599*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
3600*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3601*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3602*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3603*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3604*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3605*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3606*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3607*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3608*4bdc9457SAndroid Build Coastguard Worker }
3609*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_decreasing_batch_depthwise)3610*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_decreasing_batch_depthwise) {
3611*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3612*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3613*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
3614*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
3615*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3616*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3617*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3618*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3619*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3620*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3621*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3622*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3623*4bdc9457SAndroid Build Coastguard Worker }
3624*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_height)3625*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_height) {
3626*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3627*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3628*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3629*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3630*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3631*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
3632*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3633*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3634*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3635*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3636*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3637*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3638*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3639*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3640*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3641*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
3642*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3643*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3644*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3645*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3646*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3647*4bdc9457SAndroid Build Coastguard Worker }
3648*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_height_grouped)3649*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_height_grouped) {
3650*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3651*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3652*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3653*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3654*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3655*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
3656*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3657*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3658*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3659*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3660*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3661*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3662*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3663*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3664*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3665*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3666*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
3667*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3668*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3669*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3670*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3671*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3672*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3673*4bdc9457SAndroid Build Coastguard Worker }
3674*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_height_depthwise)3675*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_height_depthwise) {
3676*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3677*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3678*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3679*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3680*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3681*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
3682*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3683*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3684*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3685*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3686*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3687*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3688*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3689*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3690*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3691*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3692*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
3693*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3694*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3695*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3696*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3697*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3698*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3699*4bdc9457SAndroid Build Coastguard Worker }
3700*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_width)3701*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_width) {
3702*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3703*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3704*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3705*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3706*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3707*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3708*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3709*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3710*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3711*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3712*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3713*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3714*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3715*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3716*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3717*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
3718*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3719*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3720*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3721*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3722*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3723*4bdc9457SAndroid Build Coastguard Worker }
3724*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_width_grouped)3725*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_width_grouped) {
3726*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3727*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3728*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3729*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3730*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3731*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3732*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3733*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3734*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3735*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3736*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3737*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3738*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3739*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3740*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3741*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3742*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
3743*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3744*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3745*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3746*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3747*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3748*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3749*4bdc9457SAndroid Build Coastguard Worker }
3750*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_changing_width_depthwise)3751*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_changing_width_depthwise) {
3752*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3753*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3754*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3755*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3756*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3757*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3758*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3759*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3760*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3761*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3762*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3763*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3764*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3765*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3766*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
3767*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3768*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
3769*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3770*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3771*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3772*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3773*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3774*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3775*4bdc9457SAndroid Build Coastguard Worker }
3776*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_swap_height_and_width)3777*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_swap_height_and_width) {
3778*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3779*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3780*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3781*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
3782*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3783*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
3784*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3785*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3786*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3787*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3788*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3789*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3790*4bdc9457SAndroid Build Coastguard Worker }
3791*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_swap_height_and_width_grouped)3792*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_swap_height_and_width_grouped) {
3793*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3794*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3795*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3796*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
3797*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3798*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
3799*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3800*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
3801*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3802*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3803*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
3804*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
3805*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3806*4bdc9457SAndroid Build Coastguard Worker }
3807*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_QU8,setup_swap_height_and_width_depthwise)3808*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_QU8, setup_swap_height_and_width_depthwise) {
3809*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
3810*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3811*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3812*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
3813*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
3814*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
3815*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
3816*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
3817*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
3818*4bdc9457SAndroid Build Coastguard Worker .groups(19)
3819*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
3820*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
3821*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxQU8();
3822*4bdc9457SAndroid Build Coastguard Worker }
3823*4bdc9457SAndroid Build Coastguard Worker
3824*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1) {
3825*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3826*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3827*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3828*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3829*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3830*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3831*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3832*4bdc9457SAndroid Build Coastguard Worker }
3833*4bdc9457SAndroid Build Coastguard Worker
3834*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_with_qmin) {
3835*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3836*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3837*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3838*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3839*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3840*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3841*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3842*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3843*4bdc9457SAndroid Build Coastguard Worker }
3844*4bdc9457SAndroid Build Coastguard Worker
3845*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_with_qmax) {
3846*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3847*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3848*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3849*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3850*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3851*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3852*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3853*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3854*4bdc9457SAndroid Build Coastguard Worker }
3855*4bdc9457SAndroid Build Coastguard Worker
3856*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_with_input_stride) {
3857*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3858*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3859*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3860*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
3861*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3862*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3863*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3864*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3865*4bdc9457SAndroid Build Coastguard Worker }
3866*4bdc9457SAndroid Build Coastguard Worker
3867*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_with_output_stride) {
3868*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3869*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
3870*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3871*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
3872*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3873*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3874*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3875*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3876*4bdc9457SAndroid Build Coastguard Worker }
3877*4bdc9457SAndroid Build Coastguard Worker
3878*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_without_bias) {
3879*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3880*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3881*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
3882*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3883*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3884*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3885*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3886*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3887*4bdc9457SAndroid Build Coastguard Worker }
3888*4bdc9457SAndroid Build Coastguard Worker
3889*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x1_with_batch) {
3890*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3891*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3892*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
3893*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3894*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3895*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3896*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3897*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3898*4bdc9457SAndroid Build Coastguard Worker }
3899*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1)3900*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1) {
3901*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3902*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3903*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3904*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3905*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3906*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3907*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3908*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3909*4bdc9457SAndroid Build Coastguard Worker }
3910*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_with_qmin)3911*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_with_qmin) {
3912*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3913*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3914*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3915*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3916*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3917*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3918*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
3919*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3920*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3921*4bdc9457SAndroid Build Coastguard Worker }
3922*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_with_qmax)3923*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_with_qmax) {
3924*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3925*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3926*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3927*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3928*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3929*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3930*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
3931*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3932*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3933*4bdc9457SAndroid Build Coastguard Worker }
3934*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_with_input_stride)3935*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_with_input_stride) {
3936*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3937*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3938*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3939*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3940*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
3941*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3942*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3943*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3944*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3945*4bdc9457SAndroid Build Coastguard Worker }
3946*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_with_output_stride)3947*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_with_output_stride) {
3948*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3949*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3950*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3951*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3952*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
3953*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3954*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3955*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3956*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3957*4bdc9457SAndroid Build Coastguard Worker }
3958*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_without_bias)3959*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_without_bias) {
3960*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3961*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
3962*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3963*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3964*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3965*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3966*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3967*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3968*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3969*4bdc9457SAndroid Build Coastguard Worker }
3970*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x1_with_batch)3971*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x1_with_batch) {
3972*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3973*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
3974*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
3975*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3976*4bdc9457SAndroid Build Coastguard Worker .groups(2)
3977*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
3978*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3979*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3980*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3981*4bdc9457SAndroid Build Coastguard Worker }
3982*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_1x1)3983*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_1x1) {
3984*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3985*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
3986*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3987*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3988*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3989*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
3990*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
3991*4bdc9457SAndroid Build Coastguard Worker }
3992*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_1x1_with_qmin)3993*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_1x1_with_qmin) {
3994*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
3995*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
3996*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
3997*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
3998*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
3999*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4000*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4001*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4002*4bdc9457SAndroid Build Coastguard Worker }
4003*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_1x1_with_qmax)4004*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_1x1_with_qmax) {
4005*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4006*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4007*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4008*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4009*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4010*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4011*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4012*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4013*4bdc9457SAndroid Build Coastguard Worker }
4014*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_1x1_with_input_stride)4015*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_1x1_with_input_stride) {
4016*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4017*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4018*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4019*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
4020*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4021*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4022*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4023*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4024*4bdc9457SAndroid Build Coastguard Worker }
4025*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_1x1_with_output_stride)4026*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_1x1_with_output_stride) {
4027*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4028*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4029*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4030*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
4031*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4032*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4033*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4034*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4035*4bdc9457SAndroid Build Coastguard Worker }
4036*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_1x1)4037*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_1x1) {
4038*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4039*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4040*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4041*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4042*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4043*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4044*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4045*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4046*4bdc9457SAndroid Build Coastguard Worker }
4047*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_1x1_with_qmin)4048*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_1x1_with_qmin) {
4049*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4050*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4051*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4052*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4053*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4054*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4055*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4056*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4057*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4058*4bdc9457SAndroid Build Coastguard Worker }
4059*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_1x1_with_qmax)4060*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_1x1_with_qmax) {
4061*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4062*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4063*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4064*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4065*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4066*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4067*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4068*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4069*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4070*4bdc9457SAndroid Build Coastguard Worker }
4071*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_1x1_with_input_stride)4072*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_1x1_with_input_stride) {
4073*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4074*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4075*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4076*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4077*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
4078*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4079*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4080*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4081*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4082*4bdc9457SAndroid Build Coastguard Worker }
4083*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_1x1_with_output_stride)4084*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_1x1_with_output_stride) {
4085*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4086*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
4087*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4088*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4089*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
4090*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4091*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4092*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4093*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4094*4bdc9457SAndroid Build Coastguard Worker }
4095*4bdc9457SAndroid Build Coastguard Worker
4096*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 1x3) {
4097*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4098*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
4099*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
4100*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
4101*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4102*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
4103*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4104*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4105*4bdc9457SAndroid Build Coastguard Worker }
4106*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_1x3)4107*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_1x3) {
4108*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4109*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
4110*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
4111*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
4112*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4113*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4114*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
4115*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4116*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4117*4bdc9457SAndroid Build Coastguard Worker }
4118*4bdc9457SAndroid Build Coastguard Worker
4119*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x1) {
4120*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4121*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
4122*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
4123*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
4124*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4125*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
4126*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4127*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4128*4bdc9457SAndroid Build Coastguard Worker }
4129*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x1)4130*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x1) {
4131*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4132*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
4133*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
4134*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
4135*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4136*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4137*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
4138*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4139*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4140*4bdc9457SAndroid Build Coastguard Worker }
4141*4bdc9457SAndroid Build Coastguard Worker
4142*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3) {
4143*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4144*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4145*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4146*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4147*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4148*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4149*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4150*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4151*4bdc9457SAndroid Build Coastguard Worker }
4152*4bdc9457SAndroid Build Coastguard Worker
4153*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_without_padding) {
4154*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4155*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4156*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4157*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4158*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4159*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4160*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4161*4bdc9457SAndroid Build Coastguard Worker }
4162*4bdc9457SAndroid Build Coastguard Worker
4163*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_left_padding) {
4164*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4165*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4166*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4167*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4168*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4169*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4170*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4171*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4172*4bdc9457SAndroid Build Coastguard Worker }
4173*4bdc9457SAndroid Build Coastguard Worker
4174*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_right_padding) {
4175*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4176*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4177*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4178*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4179*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4180*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4181*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4182*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4183*4bdc9457SAndroid Build Coastguard Worker }
4184*4bdc9457SAndroid Build Coastguard Worker
4185*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_top_padding) {
4186*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4187*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4188*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4189*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4190*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4191*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4192*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4193*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4194*4bdc9457SAndroid Build Coastguard Worker }
4195*4bdc9457SAndroid Build Coastguard Worker
4196*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_bottom_padding) {
4197*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4198*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4199*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4200*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4201*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4202*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4203*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4204*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4205*4bdc9457SAndroid Build Coastguard Worker }
4206*4bdc9457SAndroid Build Coastguard Worker
4207*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_input_stride) {
4208*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4209*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4210*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4211*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4212*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
4213*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4214*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4215*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4216*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4217*4bdc9457SAndroid Build Coastguard Worker }
4218*4bdc9457SAndroid Build Coastguard Worker
4219*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_output_stride) {
4220*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4221*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4222*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4223*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4224*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
4225*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4226*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4227*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4228*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4229*4bdc9457SAndroid Build Coastguard Worker }
4230*4bdc9457SAndroid Build Coastguard Worker
4231*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_without_bias) {
4232*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4233*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4234*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
4235*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4236*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4237*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4238*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4239*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4240*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4241*4bdc9457SAndroid Build Coastguard Worker }
4242*4bdc9457SAndroid Build Coastguard Worker
4243*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3_with_batch) {
4244*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4245*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
4246*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
4247*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4248*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4249*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4250*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4251*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4252*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4253*4bdc9457SAndroid Build Coastguard Worker }
4254*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3)4255*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3) {
4256*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4257*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4258*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4259*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4260*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4261*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4262*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4263*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4264*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4265*4bdc9457SAndroid Build Coastguard Worker }
4266*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_without_padding)4267*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_without_padding) {
4268*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4269*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4270*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4271*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4272*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4273*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4274*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4275*4bdc9457SAndroid Build Coastguard Worker }
4276*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_left_padding)4277*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_left_padding) {
4278*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4279*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4280*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
4281*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4282*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4283*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4284*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4285*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4286*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4287*4bdc9457SAndroid Build Coastguard Worker }
4288*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_right_padding)4289*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_right_padding) {
4290*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4291*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4292*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
4293*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4294*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4295*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4296*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4297*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4298*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4299*4bdc9457SAndroid Build Coastguard Worker }
4300*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_top_padding)4301*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_top_padding) {
4302*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4303*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4304*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
4305*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4306*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4307*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4308*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4309*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4310*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4311*4bdc9457SAndroid Build Coastguard Worker }
4312*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_bottom_padding)4313*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_bottom_padding) {
4314*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4315*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4316*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
4317*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4318*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4319*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4320*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4321*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4322*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4323*4bdc9457SAndroid Build Coastguard Worker }
4324*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_input_stride)4325*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_input_stride) {
4326*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4327*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4328*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4329*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4330*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4331*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
4332*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4333*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4334*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4335*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4336*4bdc9457SAndroid Build Coastguard Worker }
4337*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_output_stride)4338*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_output_stride) {
4339*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4340*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4341*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4342*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4343*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4344*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
4345*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4346*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4347*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4348*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4349*4bdc9457SAndroid Build Coastguard Worker }
4350*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_without_bias)4351*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_without_bias) {
4352*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4353*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4354*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4355*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4356*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4357*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4358*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4359*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4360*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4361*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4362*4bdc9457SAndroid Build Coastguard Worker }
4363*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,grouped_3x3_with_batch)4364*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, grouped_3x3_with_batch) {
4365*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4366*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
4367*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
4368*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4369*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4370*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4371*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
4372*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4373*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4374*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4375*4bdc9457SAndroid Build Coastguard Worker }
4376*4bdc9457SAndroid Build Coastguard Worker
4377*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s2) {
4378*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4379*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
4380*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4381*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4382*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4383*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4384*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4385*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4386*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4387*4bdc9457SAndroid Build Coastguard Worker }
4388*4bdc9457SAndroid Build Coastguard Worker
4389*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s2_with_tf_same_padding) {
4390*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
4391*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
4392*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4393*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4394*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4395*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4396*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4397*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4398*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4399*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4400*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4401*4bdc9457SAndroid Build Coastguard Worker }
4402*4bdc9457SAndroid Build Coastguard Worker }
4403*4bdc9457SAndroid Build Coastguard Worker }
4404*4bdc9457SAndroid Build Coastguard Worker
4405*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s1x2) {
4406*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4407*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
4408*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4409*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4410*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4411*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4412*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4413*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4414*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4415*4bdc9457SAndroid Build Coastguard Worker }
4416*4bdc9457SAndroid Build Coastguard Worker
4417*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s1x2_with_tf_same_padding) {
4418*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
4419*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
4420*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4421*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4422*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4423*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4424*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4425*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4426*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4427*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4428*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4429*4bdc9457SAndroid Build Coastguard Worker }
4430*4bdc9457SAndroid Build Coastguard Worker }
4431*4bdc9457SAndroid Build Coastguard Worker }
4432*4bdc9457SAndroid Build Coastguard Worker
4433*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s2x1) {
4434*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4435*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
4436*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4437*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4438*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4439*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4440*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4441*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4442*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4443*4bdc9457SAndroid Build Coastguard Worker }
4444*4bdc9457SAndroid Build Coastguard Worker
4445*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3s2x1_with_tf_same_padding) {
4446*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
4447*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
4448*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4449*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4450*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4451*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4452*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4453*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4454*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4455*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4456*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4457*4bdc9457SAndroid Build Coastguard Worker }
4458*4bdc9457SAndroid Build Coastguard Worker }
4459*4bdc9457SAndroid Build Coastguard Worker }
4460*4bdc9457SAndroid Build Coastguard Worker
4461*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3d2) {
4462*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4463*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
4464*4bdc9457SAndroid Build Coastguard Worker .padding(2)
4465*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4466*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
4467*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4468*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4469*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4470*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4471*4bdc9457SAndroid Build Coastguard Worker }
4472*4bdc9457SAndroid Build Coastguard Worker
4473*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3d1x2) {
4474*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4475*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 15)
4476*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
4477*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4478*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
4479*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4480*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4481*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4482*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4483*4bdc9457SAndroid Build Coastguard Worker }
4484*4bdc9457SAndroid Build Coastguard Worker
4485*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, 3x3d2x1) {
4486*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4487*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4488*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
4489*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4490*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
4491*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
4492*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4493*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4494*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4495*4bdc9457SAndroid Build Coastguard Worker }
4496*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_3x3)4497*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_3x3) {
4498*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4499*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4500*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4501*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4502*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4503*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4504*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4505*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4506*4bdc9457SAndroid Build Coastguard Worker }
4507*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_3x3_with_qmin)4508*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_3x3_with_qmin) {
4509*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4510*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4511*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4512*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4513*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4514*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4515*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4516*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4517*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4518*4bdc9457SAndroid Build Coastguard Worker }
4519*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_3x3_with_qmax)4520*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_3x3_with_qmax) {
4521*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4522*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4523*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4524*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4525*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4526*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4527*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4528*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4529*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4530*4bdc9457SAndroid Build Coastguard Worker }
4531*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_3x3_with_input_stride)4532*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_3x3_with_input_stride) {
4533*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4534*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4535*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4536*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4537*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
4538*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4539*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4540*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4541*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4542*4bdc9457SAndroid Build Coastguard Worker }
4543*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_3x3_with_output_stride)4544*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_3x3_with_output_stride) {
4545*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4546*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4547*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4548*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4549*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
4550*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4551*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4552*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4553*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4554*4bdc9457SAndroid Build Coastguard Worker }
4555*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_3x3)4556*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_3x3) {
4557*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4558*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4559*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4560*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4561*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4562*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4563*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4564*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4565*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4566*4bdc9457SAndroid Build Coastguard Worker }
4567*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_3x3_with_qmin)4568*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_3x3_with_qmin) {
4569*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4570*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4571*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4572*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4573*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4574*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4575*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4576*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
4577*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4578*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4579*4bdc9457SAndroid Build Coastguard Worker }
4580*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_3x3_with_qmax)4581*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_3x3_with_qmax) {
4582*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4583*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4584*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4585*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4586*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4587*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4588*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4589*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
4590*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4591*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4592*4bdc9457SAndroid Build Coastguard Worker }
4593*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_3x3_with_input_stride)4594*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_3x3_with_input_stride) {
4595*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4596*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4597*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4598*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4599*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4600*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
4601*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4602*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4603*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4604*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4605*4bdc9457SAndroid Build Coastguard Worker }
4606*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,unioutput_grouped_3x3_with_output_stride)4607*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, unioutput_grouped_3x3_with_output_stride) {
4608*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4609*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
4610*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4611*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4612*4bdc9457SAndroid Build Coastguard Worker .groups(2)
4613*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
4614*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
4615*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
4616*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4617*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4618*4bdc9457SAndroid Build Coastguard Worker }
4619*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_1x1)4620*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_1x1) {
4621*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4622*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4623*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4624*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4625*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4626*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4627*4bdc9457SAndroid Build Coastguard Worker }
4628*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_1x1_without_bias)4629*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_1x1_without_bias) {
4630*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4631*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4632*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4633*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4634*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4635*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4636*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4637*4bdc9457SAndroid Build Coastguard Worker }
4638*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2)4639*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2) {
4640*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4641*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4642*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4643*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4644*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4645*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4646*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4647*4bdc9457SAndroid Build Coastguard Worker }
4648*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2_without_bias)4649*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2_without_bias) {
4650*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4651*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4652*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4653*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4654*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4655*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4656*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4657*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4658*4bdc9457SAndroid Build Coastguard Worker }
4659*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2s2)4660*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2s2) {
4661*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4662*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4663*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4664*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4665*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4666*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4667*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4668*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4669*4bdc9457SAndroid Build Coastguard Worker }
4670*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2s1x2)4671*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2s1x2) {
4672*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4673*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4674*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4675*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4676*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4677*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4678*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4679*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4680*4bdc9457SAndroid Build Coastguard Worker }
4681*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2s2x1)4682*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2s2x1) {
4683*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4684*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4685*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4686*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4687*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4688*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4689*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4690*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4691*4bdc9457SAndroid Build Coastguard Worker }
4692*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2d2)4693*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2d2) {
4694*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4695*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4696*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4697*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4698*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
4699*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4700*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4701*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4702*4bdc9457SAndroid Build Coastguard Worker }
4703*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2d1x2)4704*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2d1x2) {
4705*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4706*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4707*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4708*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4709*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
4710*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4711*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4712*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4713*4bdc9457SAndroid Build Coastguard Worker }
4714*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_2x2d2x1)4715*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_2x2d2x1) {
4716*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4717*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4718*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4719*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4720*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
4721*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4722*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4723*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4724*4bdc9457SAndroid Build Coastguard Worker }
4725*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3)4726*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3) {
4727*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4728*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4729*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4730*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4731*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4732*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4733*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4734*4bdc9457SAndroid Build Coastguard Worker }
4735*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3_without_bias)4736*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3_without_bias) {
4737*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4738*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4739*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4740*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4741*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4742*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4743*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4744*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4745*4bdc9457SAndroid Build Coastguard Worker }
4746*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s2)4747*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s2) {
4748*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4749*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4750*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4751*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4752*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4753*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4754*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4755*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4756*4bdc9457SAndroid Build Coastguard Worker }
4757*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s2_with_tf_same_padding)4758*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s2_with_tf_same_padding) {
4759*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
4760*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
4761*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4762*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4763*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4764*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4765*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4766*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4767*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4768*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4769*4bdc9457SAndroid Build Coastguard Worker }
4770*4bdc9457SAndroid Build Coastguard Worker }
4771*4bdc9457SAndroid Build Coastguard Worker }
4772*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s1x2)4773*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s1x2) {
4774*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4775*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4776*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4777*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4778*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4779*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4780*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4781*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4782*4bdc9457SAndroid Build Coastguard Worker }
4783*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s1x2_with_tf_same_padding)4784*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s1x2_with_tf_same_padding) {
4785*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
4786*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
4787*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4788*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4789*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4790*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4791*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4792*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4793*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4794*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4795*4bdc9457SAndroid Build Coastguard Worker }
4796*4bdc9457SAndroid Build Coastguard Worker }
4797*4bdc9457SAndroid Build Coastguard Worker }
4798*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s2x1)4799*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s2x1) {
4800*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4801*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4802*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4803*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4804*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4805*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4806*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4807*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4808*4bdc9457SAndroid Build Coastguard Worker }
4809*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3s2x1_with_tf_same_padding)4810*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3s2x1_with_tf_same_padding) {
4811*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
4812*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
4813*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4814*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
4815*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
4816*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4817*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4818*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4819*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4820*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4821*4bdc9457SAndroid Build Coastguard Worker }
4822*4bdc9457SAndroid Build Coastguard Worker }
4823*4bdc9457SAndroid Build Coastguard Worker }
4824*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3d2)4825*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3d2) {
4826*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4827*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4828*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4829*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4830*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
4831*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4832*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4833*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4834*4bdc9457SAndroid Build Coastguard Worker }
4835*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3d1x2)4836*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3d1x2) {
4837*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4838*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4839*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4840*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4841*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
4842*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4843*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4844*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4845*4bdc9457SAndroid Build Coastguard Worker }
4846*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_3x3d2x1)4847*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_3x3d2x1) {
4848*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4849*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4850*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4851*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4852*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
4853*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4854*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4855*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4856*4bdc9457SAndroid Build Coastguard Worker }
4857*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5)4858*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5) {
4859*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4860*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4861*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4862*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4863*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4864*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4865*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4866*4bdc9457SAndroid Build Coastguard Worker }
4867*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5_without_bias)4868*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5_without_bias) {
4869*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4870*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
4871*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4872*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4873*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4874*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4875*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4876*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4877*4bdc9457SAndroid Build Coastguard Worker }
4878*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5s2)4879*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5s2) {
4880*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4881*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4882*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4883*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4884*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
4885*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4886*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4887*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4888*4bdc9457SAndroid Build Coastguard Worker }
4889*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5s1x2)4890*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5s1x2) {
4891*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4892*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4893*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4894*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4895*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
4896*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4897*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4898*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4899*4bdc9457SAndroid Build Coastguard Worker }
4900*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5s2x1)4901*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5s2x1) {
4902*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4903*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4904*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4905*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4906*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
4907*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4908*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4909*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4910*4bdc9457SAndroid Build Coastguard Worker }
4911*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5d2)4912*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5d2) {
4913*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4914*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4915*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4916*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4917*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
4918*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4919*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4920*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4921*4bdc9457SAndroid Build Coastguard Worker }
4922*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5d1x2)4923*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5d1x2) {
4924*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4925*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4926*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4927*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4928*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
4929*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4930*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4931*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4932*4bdc9457SAndroid Build Coastguard Worker }
4933*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,depthwise_5x5d2x1)4934*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, depthwise_5x5d2x1) {
4935*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4936*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4937*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
4938*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
4939*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
4940*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4941*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4942*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4943*4bdc9457SAndroid Build Coastguard Worker }
4944*4bdc9457SAndroid Build Coastguard Worker
4945*4bdc9457SAndroid Build Coastguard Worker // Tests GEMM microkernel with weights_cache.
TEST(CONVOLUTION_NHWC_F32,weights_cache_1x1)4946*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, weights_cache_1x1) {
4947*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4948*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
4949*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4950*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
4951*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
4952*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
4953*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4954*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4955*4bdc9457SAndroid Build Coastguard Worker }
4956*4bdc9457SAndroid Build Coastguard Worker
4957*4bdc9457SAndroid Build Coastguard Worker // Tests IGEMM microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F32,weights_cache_3x3)4958*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, weights_cache_3x3) {
4959*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4960*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
4961*4bdc9457SAndroid Build Coastguard Worker .padding(1)
4962*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
4963*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
4964*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
4965*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
4966*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4967*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4968*4bdc9457SAndroid Build Coastguard Worker }
4969*4bdc9457SAndroid Build Coastguard Worker
4970*4bdc9457SAndroid Build Coastguard Worker // Tests vmulcaddc microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F32,weights_cache_depthwise_1x1)4971*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, weights_cache_depthwise_1x1) {
4972*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4973*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4974*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
4975*4bdc9457SAndroid Build Coastguard Worker .groups(24)
4976*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
4977*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4978*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4979*4bdc9457SAndroid Build Coastguard Worker }
4980*4bdc9457SAndroid Build Coastguard Worker
4981*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F32,weights_cache_depthwise_2x2d2)4982*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, weights_cache_depthwise_2x2d2) {
4983*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4984*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
4985*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
4986*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
4987*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
4988*4bdc9457SAndroid Build Coastguard Worker .groups(27)
4989*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
4990*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
4991*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
4992*4bdc9457SAndroid Build Coastguard Worker }
4993*4bdc9457SAndroid Build Coastguard Worker
4994*4bdc9457SAndroid Build Coastguard Worker
4995*4bdc9457SAndroid Build Coastguard Worker #if XNN_PLATFORM_JIT && XNN_ENABLE_JIT
TEST(CONVOLUTION_NHWC_F32,jit_1x1)4996*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1) {
4997*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
4998*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
4999*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5000*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5001*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5002*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5003*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5004*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5005*4bdc9457SAndroid Build Coastguard Worker }
5006*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_with_qmin)5007*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_with_qmin) {
5008*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5009*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
5010*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5011*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5012*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5013*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5014*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5015*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5016*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5017*4bdc9457SAndroid Build Coastguard Worker }
5018*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_with_qmax)5019*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_with_qmax) {
5020*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5021*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
5022*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5023*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5024*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5025*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5026*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5027*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5028*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5029*4bdc9457SAndroid Build Coastguard Worker }
5030*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_with_input_stride)5031*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_with_input_stride) {
5032*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5033*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
5034*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5035*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
5036*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5037*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5038*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5039*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5040*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5041*4bdc9457SAndroid Build Coastguard Worker }
5042*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_with_output_stride)5043*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_with_output_stride) {
5044*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5045*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
5046*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5047*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
5048*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5049*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5050*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5051*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5052*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5053*4bdc9457SAndroid Build Coastguard Worker }
5054*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_without_bias)5055*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_without_bias) {
5056*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5057*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5058*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
5059*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5060*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5061*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5062*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5063*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5064*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5065*4bdc9457SAndroid Build Coastguard Worker }
5066*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x1_with_batch)5067*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x1_with_batch) {
5068*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5069*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
5070*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
5071*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5072*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5073*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5074*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5075*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5076*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5077*4bdc9457SAndroid Build Coastguard Worker }
5078*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1)5079*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1) {
5080*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5081*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5082*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5083*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5084*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5085*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5086*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5087*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5088*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5089*4bdc9457SAndroid Build Coastguard Worker }
5090*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_with_qmin)5091*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_with_qmin) {
5092*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5093*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5094*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5095*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5096*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5097*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5098*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5099*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5100*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5101*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5102*4bdc9457SAndroid Build Coastguard Worker }
5103*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_with_qmax)5104*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_with_qmax) {
5105*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5106*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5107*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5108*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5109*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5110*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5111*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5112*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5113*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5114*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5115*4bdc9457SAndroid Build Coastguard Worker }
5116*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_with_input_stride)5117*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_with_input_stride) {
5118*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5119*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5120*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5121*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5122*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
5123*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5124*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5125*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5126*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5127*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5128*4bdc9457SAndroid Build Coastguard Worker }
5129*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_with_output_stride)5130*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_with_output_stride) {
5131*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5132*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5133*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5134*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5135*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
5136*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5137*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5138*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5139*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5140*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5141*4bdc9457SAndroid Build Coastguard Worker }
5142*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_without_bias)5143*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_without_bias) {
5144*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5145*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5146*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5147*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5148*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5149*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5150*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5151*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5152*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5153*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5154*4bdc9457SAndroid Build Coastguard Worker }
5155*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x1_with_batch)5156*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x1_with_batch) {
5157*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5158*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
5159*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
5160*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5161*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5162*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5163*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5164*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5165*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5166*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5167*4bdc9457SAndroid Build Coastguard Worker }
5168*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_1x1)5169*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_1x1) {
5170*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5171*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5172*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5173*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5174*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5175*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5176*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5177*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5178*4bdc9457SAndroid Build Coastguard Worker }
5179*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_1x1_with_qmin)5180*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_1x1_with_qmin) {
5181*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5182*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5183*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5184*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5185*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5186*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5187*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5188*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5189*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5190*4bdc9457SAndroid Build Coastguard Worker }
5191*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_1x1_with_qmax)5192*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_1x1_with_qmax) {
5193*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5194*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5195*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5196*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5197*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5198*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5199*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5200*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5201*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5202*4bdc9457SAndroid Build Coastguard Worker }
5203*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_1x1_with_input_stride)5204*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_1x1_with_input_stride) {
5205*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5206*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5207*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5208*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
5209*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5210*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5211*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5212*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5213*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5214*4bdc9457SAndroid Build Coastguard Worker }
5215*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_1x1_with_output_stride)5216*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_1x1_with_output_stride) {
5217*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5218*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5219*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5220*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
5221*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5222*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5223*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5224*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5225*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5226*4bdc9457SAndroid Build Coastguard Worker }
5227*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_1x1)5228*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_1x1) {
5229*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5230*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5231*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5232*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5233*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5234*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5235*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5236*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5237*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5238*4bdc9457SAndroid Build Coastguard Worker }
5239*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_1x1_with_qmin)5240*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_1x1_with_qmin) {
5241*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5242*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5243*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5244*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5245*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5246*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5247*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5248*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5249*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5250*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5251*4bdc9457SAndroid Build Coastguard Worker }
5252*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_1x1_with_qmax)5253*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_1x1_with_qmax) {
5254*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5255*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5256*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5257*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5258*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5259*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5260*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5261*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5262*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5263*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5264*4bdc9457SAndroid Build Coastguard Worker }
5265*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_1x1_with_input_stride)5266*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_1x1_with_input_stride) {
5267*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5268*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5269*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5270*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5271*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
5272*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5273*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5274*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5275*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5276*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5277*4bdc9457SAndroid Build Coastguard Worker }
5278*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_1x1_with_output_stride)5279*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_1x1_with_output_stride) {
5280*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5281*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
5282*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5283*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5284*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
5285*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5286*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5287*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5288*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5289*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5290*4bdc9457SAndroid Build Coastguard Worker }
5291*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_1x3)5292*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_1x3) {
5293*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5294*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
5295*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
5296*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
5297*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5298*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
5299*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5300*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5301*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5302*4bdc9457SAndroid Build Coastguard Worker }
5303*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_1x3)5304*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_1x3) {
5305*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5306*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
5307*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
5308*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
5309*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5310*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5311*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
5312*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5313*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5314*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5315*4bdc9457SAndroid Build Coastguard Worker }
5316*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x1)5317*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x1) {
5318*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5319*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
5320*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
5321*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
5322*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5323*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
5324*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5325*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5326*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5327*4bdc9457SAndroid Build Coastguard Worker }
5328*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x1)5329*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x1) {
5330*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5331*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
5332*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
5333*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
5334*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5335*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5336*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
5337*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5338*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5339*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5340*4bdc9457SAndroid Build Coastguard Worker }
5341*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3)5342*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3) {
5343*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5344*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5345*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5346*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5347*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5348*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5349*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5350*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5351*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5352*4bdc9457SAndroid Build Coastguard Worker }
5353*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_without_padding)5354*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_without_padding) {
5355*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5356*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5357*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5358*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5359*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5360*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5361*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5362*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5363*4bdc9457SAndroid Build Coastguard Worker }
5364*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_left_padding)5365*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_left_padding) {
5366*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5367*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5368*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
5369*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5370*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5371*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5372*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5373*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5374*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5375*4bdc9457SAndroid Build Coastguard Worker }
5376*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_right_padding)5377*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_right_padding) {
5378*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5379*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5380*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
5381*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5382*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5383*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5384*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5385*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5386*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5387*4bdc9457SAndroid Build Coastguard Worker }
5388*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_top_padding)5389*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_top_padding) {
5390*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5391*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5392*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
5393*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5394*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5395*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5396*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5397*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5398*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5399*4bdc9457SAndroid Build Coastguard Worker }
5400*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_bottom_padding)5401*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_bottom_padding) {
5402*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5403*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5404*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
5405*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5406*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5407*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5408*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5409*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5410*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5411*4bdc9457SAndroid Build Coastguard Worker }
5412*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_input_stride)5413*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_input_stride) {
5414*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5415*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5416*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5417*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5418*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
5419*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5420*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5421*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5422*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5423*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5424*4bdc9457SAndroid Build Coastguard Worker }
5425*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_output_stride)5426*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_output_stride) {
5427*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5428*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5429*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5430*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5431*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
5432*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5433*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5434*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5435*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5436*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5437*4bdc9457SAndroid Build Coastguard Worker }
5438*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_without_bias)5439*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_without_bias) {
5440*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5441*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5442*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
5443*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5444*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5445*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5446*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5447*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5448*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5449*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5450*4bdc9457SAndroid Build Coastguard Worker }
5451*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3_with_batch)5452*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3_with_batch) {
5453*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5454*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
5455*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
5456*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5457*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5458*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5459*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5460*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5461*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5462*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5463*4bdc9457SAndroid Build Coastguard Worker }
5464*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3)5465*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3) {
5466*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5467*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5468*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5469*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5470*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5471*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5472*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5473*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5474*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5475*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5476*4bdc9457SAndroid Build Coastguard Worker }
5477*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_without_padding)5478*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_without_padding) {
5479*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5480*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
5481*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5482*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
5483*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
5484*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5485*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5486*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5487*4bdc9457SAndroid Build Coastguard Worker }
5488*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_left_padding)5489*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_left_padding) {
5490*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5491*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5492*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
5493*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5494*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5495*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5496*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5497*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5498*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5499*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5500*4bdc9457SAndroid Build Coastguard Worker }
5501*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_right_padding)5502*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_right_padding) {
5503*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5504*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5505*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
5506*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5507*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5508*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5509*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5510*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5511*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5512*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5513*4bdc9457SAndroid Build Coastguard Worker }
5514*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_top_padding)5515*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_top_padding) {
5516*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5517*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5518*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
5519*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5520*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5521*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5522*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5523*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5524*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5525*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5526*4bdc9457SAndroid Build Coastguard Worker }
5527*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_bottom_padding)5528*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_bottom_padding) {
5529*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5530*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5531*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
5532*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5533*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5534*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5535*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5536*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5537*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5538*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5539*4bdc9457SAndroid Build Coastguard Worker }
5540*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_input_stride)5541*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_input_stride) {
5542*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5543*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5544*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5545*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5546*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5547*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
5548*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5549*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5550*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5551*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5552*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5553*4bdc9457SAndroid Build Coastguard Worker }
5554*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_output_stride)5555*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_output_stride) {
5556*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5557*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5558*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5559*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5560*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5561*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
5562*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5563*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5564*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5565*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5566*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5567*4bdc9457SAndroid Build Coastguard Worker }
5568*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_without_bias)5569*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_without_bias) {
5570*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5571*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5572*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5573*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5574*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5575*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5576*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5577*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5578*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5579*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5580*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5581*4bdc9457SAndroid Build Coastguard Worker }
5582*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_grouped_3x3_with_batch)5583*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_grouped_3x3_with_batch) {
5584*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5585*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
5586*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
5587*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5588*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5589*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5590*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
5591*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5592*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5593*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5594*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5595*4bdc9457SAndroid Build Coastguard Worker }
5596*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s2)5597*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s2) {
5598*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5599*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
5600*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5601*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5602*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
5603*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5604*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5605*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5606*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5607*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5608*4bdc9457SAndroid Build Coastguard Worker }
5609*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s2_with_tf_same_padding)5610*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s2_with_tf_same_padding) {
5611*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
5612*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
5613*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5614*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
5615*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5616*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5617*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
5618*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5619*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5620*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5621*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5622*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5623*4bdc9457SAndroid Build Coastguard Worker }
5624*4bdc9457SAndroid Build Coastguard Worker }
5625*4bdc9457SAndroid Build Coastguard Worker }
5626*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s1x2)5627*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s1x2) {
5628*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5629*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
5630*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5631*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5632*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
5633*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5634*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5635*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5636*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5637*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5638*4bdc9457SAndroid Build Coastguard Worker }
5639*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s1x2_with_tf_same_padding)5640*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s1x2_with_tf_same_padding) {
5641*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
5642*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
5643*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5644*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
5645*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5646*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5647*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
5648*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5649*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5650*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5651*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5652*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5653*4bdc9457SAndroid Build Coastguard Worker }
5654*4bdc9457SAndroid Build Coastguard Worker }
5655*4bdc9457SAndroid Build Coastguard Worker }
5656*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s2x1)5657*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s2x1) {
5658*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5659*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
5660*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5661*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5662*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
5663*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5664*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5665*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5666*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5667*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5668*4bdc9457SAndroid Build Coastguard Worker }
5669*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3s2x1_with_tf_same_padding)5670*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3s2x1_with_tf_same_padding) {
5671*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
5672*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
5673*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5674*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
5675*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
5676*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5677*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
5678*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5679*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5680*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5681*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5682*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5683*4bdc9457SAndroid Build Coastguard Worker }
5684*4bdc9457SAndroid Build Coastguard Worker }
5685*4bdc9457SAndroid Build Coastguard Worker }
5686*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3d2)5687*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3d2) {
5688*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5689*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
5690*4bdc9457SAndroid Build Coastguard Worker .padding(2)
5691*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5692*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
5693*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5694*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5695*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5696*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5697*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5698*4bdc9457SAndroid Build Coastguard Worker }
5699*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3d1x2)5700*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3d1x2) {
5701*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5702*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 15)
5703*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
5704*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5705*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
5706*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5707*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5708*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5709*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5710*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5711*4bdc9457SAndroid Build Coastguard Worker }
5712*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_3x3d2x1)5713*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_3x3d2x1) {
5714*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5715*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5716*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
5717*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5718*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
5719*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
5720*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5721*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5722*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5723*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5724*4bdc9457SAndroid Build Coastguard Worker }
5725*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_3x3)5726*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_3x3) {
5727*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5728*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5729*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5730*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5731*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5732*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5733*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5734*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5735*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5736*4bdc9457SAndroid Build Coastguard Worker }
5737*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_3x3_with_qmin)5738*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_3x3_with_qmin) {
5739*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5740*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5741*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5742*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5743*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5744*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5745*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5746*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5747*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5748*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5749*4bdc9457SAndroid Build Coastguard Worker }
5750*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_3x3_with_qmax)5751*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_3x3_with_qmax) {
5752*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5753*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5754*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5755*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5756*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5757*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5758*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5759*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5760*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5761*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5762*4bdc9457SAndroid Build Coastguard Worker }
5763*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_3x3_with_input_stride)5764*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_3x3_with_input_stride) {
5765*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5766*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5767*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5768*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5769*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
5770*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5771*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5772*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5773*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5774*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5775*4bdc9457SAndroid Build Coastguard Worker }
5776*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_3x3_with_output_stride)5777*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_3x3_with_output_stride) {
5778*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5779*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5780*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5781*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5782*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
5783*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
5784*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
5785*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5786*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5787*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5788*4bdc9457SAndroid Build Coastguard Worker }
5789*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_3x3)5790*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_3x3) {
5791*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5792*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5793*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5794*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5795*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5796*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5797*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5798*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5799*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5800*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5801*4bdc9457SAndroid Build Coastguard Worker }
5802*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_3x3_with_qmin)5803*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_3x3_with_qmin) {
5804*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5805*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5806*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5807*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5808*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5809*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5810*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5811*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
5812*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5813*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5814*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5815*4bdc9457SAndroid Build Coastguard Worker }
5816*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_3x3_with_qmax)5817*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_3x3_with_qmax) {
5818*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5819*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5820*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5821*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5822*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5823*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5824*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5825*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
5826*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5827*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5828*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5829*4bdc9457SAndroid Build Coastguard Worker }
5830*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_3x3_with_input_stride)5831*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_3x3_with_input_stride) {
5832*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5833*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5834*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5835*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5836*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5837*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
5838*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5839*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5840*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5841*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5842*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5843*4bdc9457SAndroid Build Coastguard Worker }
5844*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,jit_unioutput_grouped_3x3_with_output_stride)5845*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_unioutput_grouped_3x3_with_output_stride) {
5846*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5847*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
5848*4bdc9457SAndroid Build Coastguard Worker .padding(1)
5849*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5850*4bdc9457SAndroid Build Coastguard Worker .groups(2)
5851*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
5852*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
5853*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
5854*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5855*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5856*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5857*4bdc9457SAndroid Build Coastguard Worker }
5858*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_1x1)5859*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_1x1) {
5860*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5861*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5862*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5863*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5864*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5865*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5866*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5867*4bdc9457SAndroid Build Coastguard Worker }
5868*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_1x1_without_bias)5869*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_1x1_without_bias) {
5870*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5871*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5872*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5873*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
5874*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5875*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5876*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5877*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5878*4bdc9457SAndroid Build Coastguard Worker }
5879*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2)5880*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2) {
5881*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5882*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5883*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5884*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5885*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5886*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5887*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5888*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5889*4bdc9457SAndroid Build Coastguard Worker }
5890*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2_without_bias)5891*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2_without_bias) {
5892*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5893*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5894*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5895*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5896*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5897*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5898*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5899*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5900*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5901*4bdc9457SAndroid Build Coastguard Worker }
5902*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2s2)5903*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2s2) {
5904*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5905*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5906*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5907*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5908*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
5909*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5910*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5911*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5912*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5913*4bdc9457SAndroid Build Coastguard Worker }
5914*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2s1x2)5915*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2s1x2) {
5916*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5917*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5918*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5919*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5920*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
5921*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5922*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5923*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5924*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5925*4bdc9457SAndroid Build Coastguard Worker }
5926*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2s2x1)5927*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2s2x1) {
5928*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5929*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5930*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5931*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5932*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
5933*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5934*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5935*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5936*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5937*4bdc9457SAndroid Build Coastguard Worker }
5938*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2d2)5939*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2d2) {
5940*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5941*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5942*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5943*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5944*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
5945*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5946*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5947*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5948*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5949*4bdc9457SAndroid Build Coastguard Worker }
5950*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2d1x2)5951*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2d1x2) {
5952*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5953*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5954*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5955*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5956*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
5957*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5958*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5959*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5960*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5961*4bdc9457SAndroid Build Coastguard Worker }
5962*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_2x2d2x1)5963*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_2x2d2x1) {
5964*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5965*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5966*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5967*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
5968*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
5969*4bdc9457SAndroid Build Coastguard Worker .groups(27)
5970*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5971*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5972*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5973*4bdc9457SAndroid Build Coastguard Worker }
5974*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3)5975*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3) {
5976*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5977*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5978*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5979*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5980*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5981*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5982*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5983*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5984*4bdc9457SAndroid Build Coastguard Worker }
5985*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3_without_bias)5986*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3_without_bias) {
5987*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
5988*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
5989*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
5990*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
5991*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
5992*4bdc9457SAndroid Build Coastguard Worker .groups(24)
5993*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
5994*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
5995*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
5996*4bdc9457SAndroid Build Coastguard Worker }
5997*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s2)5998*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s2) {
5999*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6000*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6001*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6002*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6003*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
6004*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6005*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6006*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6007*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6008*4bdc9457SAndroid Build Coastguard Worker }
6009*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s2_with_tf_same_padding)6010*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s2_with_tf_same_padding) {
6011*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
6012*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
6013*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6014*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
6015*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
6016*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6017*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
6018*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6019*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6020*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6021*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6022*4bdc9457SAndroid Build Coastguard Worker }
6023*4bdc9457SAndroid Build Coastguard Worker }
6024*4bdc9457SAndroid Build Coastguard Worker }
6025*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s1x2)6026*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s1x2) {
6027*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6028*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6029*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6030*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6031*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
6032*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6033*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6034*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6035*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6036*4bdc9457SAndroid Build Coastguard Worker }
6037*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s1x2_with_tf_same_padding)6038*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s1x2_with_tf_same_padding) {
6039*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
6040*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
6041*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6042*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
6043*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
6044*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6045*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
6046*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6047*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6048*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6049*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6050*4bdc9457SAndroid Build Coastguard Worker }
6051*4bdc9457SAndroid Build Coastguard Worker }
6052*4bdc9457SAndroid Build Coastguard Worker }
6053*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s2x1)6054*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s2x1) {
6055*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6056*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6057*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6058*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6059*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
6060*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6061*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6062*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6063*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6064*4bdc9457SAndroid Build Coastguard Worker }
6065*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3s2x1_with_tf_same_padding)6066*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3s2x1_with_tf_same_padding) {
6067*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
6068*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
6069*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6070*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
6071*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
6072*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6073*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
6074*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6075*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6076*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6077*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6078*4bdc9457SAndroid Build Coastguard Worker }
6079*4bdc9457SAndroid Build Coastguard Worker }
6080*4bdc9457SAndroid Build Coastguard Worker }
6081*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3d2)6082*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3d2) {
6083*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6084*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6085*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6086*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6087*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
6088*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6089*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6090*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6091*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6092*4bdc9457SAndroid Build Coastguard Worker }
6093*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3d1x2)6094*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3d1x2) {
6095*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6096*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6097*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6098*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6099*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
6100*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6101*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6102*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6103*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6104*4bdc9457SAndroid Build Coastguard Worker }
6105*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_3x3d2x1)6106*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_3x3d2x1) {
6107*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6108*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6109*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6110*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6111*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
6112*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6113*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6114*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6115*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6116*4bdc9457SAndroid Build Coastguard Worker }
6117*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5)6118*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5) {
6119*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6120*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6121*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6122*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6123*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6124*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6125*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6126*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6127*4bdc9457SAndroid Build Coastguard Worker }
6128*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5_without_bias)6129*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5_without_bias) {
6130*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6131*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6132*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6133*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6134*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6135*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6136*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6137*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6138*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6139*4bdc9457SAndroid Build Coastguard Worker }
6140*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5s2)6141*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5s2) {
6142*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6143*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6144*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6145*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6146*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
6147*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6148*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6149*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6150*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6151*4bdc9457SAndroid Build Coastguard Worker }
6152*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5s1x2)6153*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5s1x2) {
6154*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6155*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6156*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6157*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6158*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
6159*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6160*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6161*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6162*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6163*4bdc9457SAndroid Build Coastguard Worker }
6164*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5s2x1)6165*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5s2x1) {
6166*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6167*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6168*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6169*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6170*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
6171*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6172*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6173*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6174*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6175*4bdc9457SAndroid Build Coastguard Worker }
6176*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5d2)6177*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5d2) {
6178*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6179*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6180*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6181*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6182*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
6183*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6184*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6185*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6186*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6187*4bdc9457SAndroid Build Coastguard Worker }
6188*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5d1x2)6189*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5d1x2) {
6190*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6191*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6192*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6193*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6194*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
6195*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6196*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6197*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6198*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6199*4bdc9457SAndroid Build Coastguard Worker }
6200*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,DISABLED_jit_depthwise_5x5d2x1)6201*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, DISABLED_jit_depthwise_5x5d2x1) {
6202*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6203*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6204*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6205*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6206*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
6207*4bdc9457SAndroid Build Coastguard Worker .groups(27)
6208*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6209*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6210*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6211*4bdc9457SAndroid Build Coastguard Worker }
6212*4bdc9457SAndroid Build Coastguard Worker
6213*4bdc9457SAndroid Build Coastguard Worker // Test interaction of JIT with weights cache.
TEST(CONVOLUTION_NHWC_F32,jit_weights_cache_1x1)6214*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, jit_weights_cache_1x1) {
6215*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6216*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6217*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6218*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6219*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6220*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6221*4bdc9457SAndroid Build Coastguard Worker .use_jit(true)
6222*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
6223*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6224*4bdc9457SAndroid Build Coastguard Worker }
6225*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_PLATFORM_JIT && XNN_ENABLE_JIT
6226*4bdc9457SAndroid Build Coastguard Worker
6227*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 1x1) {
6228*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6229*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6230*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6231*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6232*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6233*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6234*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6235*4bdc9457SAndroid Build Coastguard Worker }
6236*4bdc9457SAndroid Build Coastguard Worker
6237*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 1x1_with_depth_multiplier) {
6238*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6239*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6240*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6241*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6242*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6243*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
6244*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6245*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6246*4bdc9457SAndroid Build Coastguard Worker }
6247*4bdc9457SAndroid Build Coastguard Worker
6248*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 1x1_without_bias) {
6249*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6250*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6251*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6252*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6253*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6254*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6255*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6256*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6257*4bdc9457SAndroid Build Coastguard Worker }
6258*4bdc9457SAndroid Build Coastguard Worker
6259*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 2x2) {
6260*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6261*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6262*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6263*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6264*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
6265*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6266*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6267*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6268*4bdc9457SAndroid Build Coastguard Worker }
6269*4bdc9457SAndroid Build Coastguard Worker
6270*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 2x2_with_depth_multiplier) {
6271*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6272*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6273*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6274*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6275*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
6276*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6277*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
6278*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6279*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6280*4bdc9457SAndroid Build Coastguard Worker }
6281*4bdc9457SAndroid Build Coastguard Worker
6282*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 2x2_without_bias) {
6283*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6284*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6285*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6286*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6287*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6288*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
6289*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6290*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6291*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6292*4bdc9457SAndroid Build Coastguard Worker }
6293*4bdc9457SAndroid Build Coastguard Worker
6294*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 3x3) {
6295*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6296*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6297*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6298*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6299*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6300*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6301*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6302*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6303*4bdc9457SAndroid Build Coastguard Worker }
6304*4bdc9457SAndroid Build Coastguard Worker
6305*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 3x3_with_depth_multiplier) {
6306*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6307*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6308*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6309*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6310*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6311*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6312*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
6313*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6314*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6315*4bdc9457SAndroid Build Coastguard Worker }
6316*4bdc9457SAndroid Build Coastguard Worker
6317*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 3x3_without_bias) {
6318*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6319*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6320*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6321*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6322*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6323*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6324*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6325*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6326*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6327*4bdc9457SAndroid Build Coastguard Worker }
6328*4bdc9457SAndroid Build Coastguard Worker
6329*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 3x3s2_with_tf_same_padding) {
6330*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
6331*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
6332*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6333*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6334*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
6335*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
6336*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
6337*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6338*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6339*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6340*4bdc9457SAndroid Build Coastguard Worker }
6341*4bdc9457SAndroid Build Coastguard Worker }
6342*4bdc9457SAndroid Build Coastguard Worker }
6343*4bdc9457SAndroid Build Coastguard Worker
6344*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 5x5) {
6345*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6346*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6347*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6348*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6349*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6350*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6351*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6352*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6353*4bdc9457SAndroid Build Coastguard Worker }
6354*4bdc9457SAndroid Build Coastguard Worker
6355*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 5x5_with_depth_multiplier) {
6356*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6357*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6358*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6359*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6360*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6361*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6362*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
6363*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6364*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6365*4bdc9457SAndroid Build Coastguard Worker }
6366*4bdc9457SAndroid Build Coastguard Worker
6367*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 5x5_without_bias) {
6368*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6369*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6370*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6371*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6372*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
6373*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
6374*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6375*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6376*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6377*4bdc9457SAndroid Build Coastguard Worker }
6378*4bdc9457SAndroid Build Coastguard Worker
6379*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 7x7) {
6380*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6381*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6382*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6383*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
6384*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
6385*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6386*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6387*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6388*4bdc9457SAndroid Build Coastguard Worker }
6389*4bdc9457SAndroid Build Coastguard Worker
6390*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, 7x7_without_bias) {
6391*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6392*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6393*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6394*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6395*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
6396*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
6397*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6398*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6399*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6400*4bdc9457SAndroid Build Coastguard Worker }
6401*4bdc9457SAndroid Build Coastguard Worker
6402*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(DEPTHWISE_CONVOLUTION_NHWC_F32,weights_cache_1x1)6403*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, weights_cache_1x1) {
6404*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6405*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6406*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6407*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6408*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6409*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
6410*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6411*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6412*4bdc9457SAndroid Build Coastguard Worker }
6413*4bdc9457SAndroid Build Coastguard Worker
6414*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernek with non 1x1 kernel (dwconv_hwg packing).
TEST(DEPTHWISE_CONVOLUTION_NHWC_F32,weights_cache_2x2)6415*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F32, weights_cache_2x2) {
6416*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6417*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
6418*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
6419*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
6420*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
6421*4bdc9457SAndroid Build Coastguard Worker .groups(24)
6422*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
6423*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6424*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF32();
6425*4bdc9457SAndroid Build Coastguard Worker }
6426*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_input_buffer)6427*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_input_buffer) {
6428*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6429*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6430*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6431*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6432*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6433*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6434*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6435*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6436*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6437*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6438*4bdc9457SAndroid Build Coastguard Worker }
6439*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_input_buffer_grouped)6440*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_input_buffer_grouped) {
6441*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6442*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6443*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6444*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6445*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6446*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6447*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6448*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6449*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6450*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6451*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6452*4bdc9457SAndroid Build Coastguard Worker }
6453*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_input_buffer_depthwise)6454*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_input_buffer_depthwise) {
6455*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6456*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6457*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6458*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6459*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6460*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6461*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6462*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6463*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6464*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6465*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6466*4bdc9457SAndroid Build Coastguard Worker }
6467*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_increasing_batch)6468*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_increasing_batch) {
6469*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6470*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6471*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6472*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
6473*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6474*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6475*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6476*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6477*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6478*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6479*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6480*4bdc9457SAndroid Build Coastguard Worker }
6481*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_increasing_batch_grouped)6482*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_increasing_batch_grouped) {
6483*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6484*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6485*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6486*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
6487*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6488*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6489*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6490*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6491*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6492*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6493*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6494*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6495*4bdc9457SAndroid Build Coastguard Worker }
6496*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_increasing_batch_depthwise)6497*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_increasing_batch_depthwise) {
6498*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6499*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6500*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6501*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
6502*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6503*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6504*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6505*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6506*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6507*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6508*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6509*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6510*4bdc9457SAndroid Build Coastguard Worker }
6511*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_decreasing_batch)6512*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_decreasing_batch) {
6513*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6514*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6515*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
6516*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
6517*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6518*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6519*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6520*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6521*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6522*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6523*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6524*4bdc9457SAndroid Build Coastguard Worker }
6525*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_decreasing_batch_grouped)6526*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_decreasing_batch_grouped) {
6527*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6528*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6529*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
6530*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
6531*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6532*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6533*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6534*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6535*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6536*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6537*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6538*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6539*4bdc9457SAndroid Build Coastguard Worker }
6540*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_decreasing_batch_depthwise)6541*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_decreasing_batch_depthwise) {
6542*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6543*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6544*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
6545*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
6546*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6547*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6548*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6549*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6550*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6551*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6552*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6553*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6554*4bdc9457SAndroid Build Coastguard Worker }
6555*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_height)6556*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_height) {
6557*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6558*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6559*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6560*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6561*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6562*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
6563*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6564*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6565*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6566*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6567*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6568*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6569*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6570*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6571*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6572*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
6573*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6574*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6575*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6576*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6577*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6578*4bdc9457SAndroid Build Coastguard Worker }
6579*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_height_grouped)6580*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_height_grouped) {
6581*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6582*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6583*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6584*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6585*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6586*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
6587*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6588*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6589*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6590*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6591*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6592*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6593*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6594*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6595*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6596*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6597*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
6598*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6599*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6600*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6601*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6602*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6603*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6604*4bdc9457SAndroid Build Coastguard Worker }
6605*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_height_depthwise)6606*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_height_depthwise) {
6607*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6608*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6609*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6610*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6611*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6612*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
6613*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6614*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6615*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6616*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6617*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6618*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6619*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6620*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6621*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6622*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6623*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
6624*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6625*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6626*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6627*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6628*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6629*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6630*4bdc9457SAndroid Build Coastguard Worker }
6631*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_width)6632*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_width) {
6633*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6634*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6635*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6636*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6637*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6638*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6639*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6640*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6641*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6642*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6643*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6644*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6645*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6646*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6647*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6648*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
6649*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6650*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6651*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6652*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6653*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6654*4bdc9457SAndroid Build Coastguard Worker }
6655*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_width_grouped)6656*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_width_grouped) {
6657*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6658*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6659*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6660*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6661*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6662*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6663*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6664*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6665*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6666*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6667*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6668*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6669*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6670*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6671*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6672*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6673*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
6674*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6675*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6676*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6677*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6678*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6679*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6680*4bdc9457SAndroid Build Coastguard Worker }
6681*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_changing_width_depthwise)6682*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_changing_width_depthwise) {
6683*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6684*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6685*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6686*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6687*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6688*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6689*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6690*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6691*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6692*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6693*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6694*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6695*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6696*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6697*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
6698*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6699*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
6700*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6701*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6702*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6703*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6704*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6705*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6706*4bdc9457SAndroid Build Coastguard Worker }
6707*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_swap_height_and_width)6708*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_swap_height_and_width) {
6709*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6710*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6711*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6712*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
6713*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6714*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
6715*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6716*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6717*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6718*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6719*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6720*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6721*4bdc9457SAndroid Build Coastguard Worker }
6722*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_swap_height_and_width_grouped)6723*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_swap_height_and_width_grouped) {
6724*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6725*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6726*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6727*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
6728*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6729*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
6730*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6731*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
6732*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6733*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6734*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
6735*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
6736*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6737*4bdc9457SAndroid Build Coastguard Worker }
6738*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F32,setup_swap_height_and_width_depthwise)6739*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F32, setup_swap_height_and_width_depthwise) {
6740*4bdc9457SAndroid Build Coastguard Worker ASSERT_EQ(xnn_status_success, xnn_initialize(nullptr /* allocator */));
6741*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6742*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6743*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
6744*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
6745*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
6746*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
6747*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
6748*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
6749*4bdc9457SAndroid Build Coastguard Worker .groups(19)
6750*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
6751*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
6752*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF32();
6753*4bdc9457SAndroid Build Coastguard Worker }
6754*4bdc9457SAndroid Build Coastguard Worker
6755*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1) {
6756*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6757*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6758*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6759*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6760*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6761*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6762*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6763*4bdc9457SAndroid Build Coastguard Worker }
6764*4bdc9457SAndroid Build Coastguard Worker
6765*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_fp32_weights) {
6766*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6767*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6768*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6769*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6770*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6771*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
6772*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6773*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6774*4bdc9457SAndroid Build Coastguard Worker }
6775*4bdc9457SAndroid Build Coastguard Worker
6776*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_qmin) {
6777*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6778*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6779*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6780*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6781*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6782*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6783*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6784*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6785*4bdc9457SAndroid Build Coastguard Worker }
6786*4bdc9457SAndroid Build Coastguard Worker
6787*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_qmax) {
6788*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6789*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6790*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6791*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6792*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6793*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6794*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6795*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6796*4bdc9457SAndroid Build Coastguard Worker }
6797*4bdc9457SAndroid Build Coastguard Worker
6798*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_input_stride) {
6799*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6800*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6801*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6802*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
6803*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6804*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6805*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6806*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6807*4bdc9457SAndroid Build Coastguard Worker }
6808*4bdc9457SAndroid Build Coastguard Worker
6809*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_output_stride) {
6810*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6811*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
6812*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6813*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
6814*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6815*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6816*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6817*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6818*4bdc9457SAndroid Build Coastguard Worker }
6819*4bdc9457SAndroid Build Coastguard Worker
6820*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_without_bias) {
6821*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6822*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6823*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
6824*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6825*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6826*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6827*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6828*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6829*4bdc9457SAndroid Build Coastguard Worker }
6830*4bdc9457SAndroid Build Coastguard Worker
6831*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x1_with_batch) {
6832*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6833*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6834*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
6835*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6836*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6837*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6838*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6839*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6840*4bdc9457SAndroid Build Coastguard Worker }
6841*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1)6842*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1) {
6843*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6844*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6845*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6846*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6847*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6848*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6849*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6850*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6851*4bdc9457SAndroid Build Coastguard Worker }
6852*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_fp32_weights)6853*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_fp32_weights) {
6854*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6855*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
6856*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6857*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6858*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6859*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6860*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6861*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6862*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6863*4bdc9457SAndroid Build Coastguard Worker }
6864*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_qmin)6865*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_qmin) {
6866*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6867*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6868*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6869*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6870*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6871*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6872*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6873*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6874*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6875*4bdc9457SAndroid Build Coastguard Worker }
6876*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_qmax)6877*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_qmax) {
6878*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6879*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6880*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6881*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6882*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6883*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6884*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6885*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6886*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6887*4bdc9457SAndroid Build Coastguard Worker }
6888*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_input_stride)6889*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_input_stride) {
6890*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6891*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6892*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6893*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6894*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
6895*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6896*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6897*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6898*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6899*4bdc9457SAndroid Build Coastguard Worker }
6900*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_output_stride)6901*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_output_stride) {
6902*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6903*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6904*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6905*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6906*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
6907*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6908*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6909*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6910*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6911*4bdc9457SAndroid Build Coastguard Worker }
6912*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_without_bias)6913*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_without_bias) {
6914*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6915*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
6916*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6917*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6918*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6919*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6920*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6921*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6922*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6923*4bdc9457SAndroid Build Coastguard Worker }
6924*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x1_with_batch)6925*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x1_with_batch) {
6926*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6927*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
6928*4bdc9457SAndroid Build Coastguard Worker .input_size(24, 25)
6929*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6930*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6931*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6932*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6933*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6934*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6935*4bdc9457SAndroid Build Coastguard Worker }
6936*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_1x1)6937*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_1x1) {
6938*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6939*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6940*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6941*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6942*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6943*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6944*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6945*4bdc9457SAndroid Build Coastguard Worker }
6946*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_1x1_with_qmin)6947*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_1x1_with_qmin) {
6948*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6949*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6950*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6951*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6952*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6953*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
6954*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6955*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6956*4bdc9457SAndroid Build Coastguard Worker }
6957*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_1x1_with_qmax)6958*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_1x1_with_qmax) {
6959*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6960*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6961*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6962*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6963*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6964*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
6965*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6966*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6967*4bdc9457SAndroid Build Coastguard Worker }
6968*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_1x1_with_input_stride)6969*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_1x1_with_input_stride) {
6970*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6971*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6972*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6973*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
6974*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6975*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6976*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6977*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6978*4bdc9457SAndroid Build Coastguard Worker }
6979*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_1x1_with_output_stride)6980*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_1x1_with_output_stride) {
6981*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6982*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6983*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6984*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
6985*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
6986*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
6987*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6988*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
6989*4bdc9457SAndroid Build Coastguard Worker }
6990*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_1x1)6991*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_1x1) {
6992*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
6993*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
6994*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
6995*4bdc9457SAndroid Build Coastguard Worker .groups(2)
6996*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
6997*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
6998*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
6999*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7000*4bdc9457SAndroid Build Coastguard Worker }
7001*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_1x1_with_qmin)7002*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_1x1_with_qmin) {
7003*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7004*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
7005*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7006*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7007*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7008*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7009*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
7010*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7011*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7012*4bdc9457SAndroid Build Coastguard Worker }
7013*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_1x1_with_qmax)7014*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_1x1_with_qmax) {
7015*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7016*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
7017*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7018*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7019*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7020*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7021*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
7022*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7023*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7024*4bdc9457SAndroid Build Coastguard Worker }
7025*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_1x1_with_input_stride)7026*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_1x1_with_input_stride) {
7027*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7028*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
7029*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7030*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7031*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
7032*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7033*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7034*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7035*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7036*4bdc9457SAndroid Build Coastguard Worker }
7037*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_1x1_with_output_stride)7038*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_1x1_with_output_stride) {
7039*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7040*4bdc9457SAndroid Build Coastguard Worker .input_size(1, 1)
7041*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7042*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7043*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
7044*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7045*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7046*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7047*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7048*4bdc9457SAndroid Build Coastguard Worker }
7049*4bdc9457SAndroid Build Coastguard Worker
7050*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 1x3) {
7051*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7052*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
7053*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
7054*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
7055*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7056*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
7057*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7058*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7059*4bdc9457SAndroid Build Coastguard Worker }
7060*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_1x3)7061*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_1x3) {
7062*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7063*4bdc9457SAndroid Build Coastguard Worker .input_size(20, 19)
7064*4bdc9457SAndroid Build Coastguard Worker .padding_width(1)
7065*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 3)
7066*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7067*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7068*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
7069*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7070*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7071*4bdc9457SAndroid Build Coastguard Worker }
7072*4bdc9457SAndroid Build Coastguard Worker
7073*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x1) {
7074*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7075*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
7076*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
7077*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
7078*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7079*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
7080*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7081*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7082*4bdc9457SAndroid Build Coastguard Worker }
7083*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x1)7084*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x1) {
7085*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7086*4bdc9457SAndroid Build Coastguard Worker .input_size(19, 20)
7087*4bdc9457SAndroid Build Coastguard Worker .padding_height(1)
7088*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 1)
7089*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7090*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7091*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(15)
7092*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7093*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7094*4bdc9457SAndroid Build Coastguard Worker }
7095*4bdc9457SAndroid Build Coastguard Worker
7096*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3) {
7097*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7098*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7099*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7100*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7101*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7102*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7103*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7104*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7105*4bdc9457SAndroid Build Coastguard Worker }
7106*4bdc9457SAndroid Build Coastguard Worker
7107*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_fp32_weights) {
7108*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7109*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
7110*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7111*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7112*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7113*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7114*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7115*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7116*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7117*4bdc9457SAndroid Build Coastguard Worker }
7118*4bdc9457SAndroid Build Coastguard Worker
7119*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_without_padding) {
7120*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7121*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7122*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7123*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7124*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7125*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7126*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7127*4bdc9457SAndroid Build Coastguard Worker }
7128*4bdc9457SAndroid Build Coastguard Worker
7129*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_left_padding) {
7130*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7131*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7132*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
7133*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7134*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7135*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7136*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7137*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7138*4bdc9457SAndroid Build Coastguard Worker }
7139*4bdc9457SAndroid Build Coastguard Worker
7140*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_right_padding) {
7141*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7142*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7143*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
7144*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7145*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7146*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7147*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7148*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7149*4bdc9457SAndroid Build Coastguard Worker }
7150*4bdc9457SAndroid Build Coastguard Worker
7151*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_top_padding) {
7152*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7153*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7154*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
7155*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7156*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7157*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7158*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7159*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7160*4bdc9457SAndroid Build Coastguard Worker }
7161*4bdc9457SAndroid Build Coastguard Worker
7162*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_bottom_padding) {
7163*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7164*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7165*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
7166*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7167*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7168*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7169*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7170*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7171*4bdc9457SAndroid Build Coastguard Worker }
7172*4bdc9457SAndroid Build Coastguard Worker
7173*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_input_stride) {
7174*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7175*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7176*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7177*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7178*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(22)
7179*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7180*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7181*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7182*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7183*4bdc9457SAndroid Build Coastguard Worker }
7184*4bdc9457SAndroid Build Coastguard Worker
7185*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_output_stride) {
7186*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7187*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7188*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7189*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7190*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(23)
7191*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7192*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7193*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7194*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7195*4bdc9457SAndroid Build Coastguard Worker }
7196*4bdc9457SAndroid Build Coastguard Worker
7197*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_without_bias) {
7198*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7199*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7200*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
7201*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7202*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7203*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7204*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7205*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7206*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7207*4bdc9457SAndroid Build Coastguard Worker }
7208*4bdc9457SAndroid Build Coastguard Worker
7209*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3_with_batch) {
7210*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7211*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
7212*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 9)
7213*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7214*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7215*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7216*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7217*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7218*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7219*4bdc9457SAndroid Build Coastguard Worker }
7220*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3)7221*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3) {
7222*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7223*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7224*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7225*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7226*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7227*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7228*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7229*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7230*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7231*4bdc9457SAndroid Build Coastguard Worker }
7232*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_fp32_weights)7233*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_fp32_weights) {
7234*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7235*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
7236*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7237*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7238*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7239*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7240*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7241*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7242*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7243*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7244*4bdc9457SAndroid Build Coastguard Worker }
7245*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_without_padding)7246*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_without_padding) {
7247*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7248*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7249*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7250*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7251*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7252*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7253*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7254*4bdc9457SAndroid Build Coastguard Worker }
7255*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_left_padding)7256*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_left_padding) {
7257*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7258*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7259*4bdc9457SAndroid Build Coastguard Worker .padding_left(1)
7260*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7261*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7262*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7263*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7264*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7265*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7266*4bdc9457SAndroid Build Coastguard Worker }
7267*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_right_padding)7268*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_right_padding) {
7269*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7270*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7271*4bdc9457SAndroid Build Coastguard Worker .padding_right(1)
7272*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7273*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7274*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7275*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7276*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7277*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7278*4bdc9457SAndroid Build Coastguard Worker }
7279*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_top_padding)7280*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_top_padding) {
7281*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7282*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7283*4bdc9457SAndroid Build Coastguard Worker .padding_top(1)
7284*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7285*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7286*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7287*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7288*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7289*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7290*4bdc9457SAndroid Build Coastguard Worker }
7291*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_bottom_padding)7292*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_bottom_padding) {
7293*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7294*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7295*4bdc9457SAndroid Build Coastguard Worker .padding_bottom(1)
7296*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7297*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7298*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7299*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7300*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7301*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7302*4bdc9457SAndroid Build Coastguard Worker }
7303*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_input_stride)7304*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_input_stride) {
7305*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7306*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7307*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7308*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7309*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7310*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(29)
7311*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7312*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7313*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7314*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7315*4bdc9457SAndroid Build Coastguard Worker }
7316*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_output_stride)7317*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_output_stride) {
7318*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7319*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7320*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7321*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7322*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7323*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(31)
7324*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7325*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7326*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7327*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7328*4bdc9457SAndroid Build Coastguard Worker }
7329*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_without_bias)7330*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_without_bias) {
7331*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7332*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7333*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7334*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7335*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7336*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7337*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7338*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7339*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7340*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7341*4bdc9457SAndroid Build Coastguard Worker }
7342*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,grouped_3x3_with_batch)7343*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, grouped_3x3_with_batch) {
7344*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7345*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
7346*4bdc9457SAndroid Build Coastguard Worker .input_size(10, 11)
7347*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7348*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7349*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7350*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(14)
7351*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7352*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7353*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7354*4bdc9457SAndroid Build Coastguard Worker }
7355*4bdc9457SAndroid Build Coastguard Worker
7356*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s2) {
7357*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7358*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
7359*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7360*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7361*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7362*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7363*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7364*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7365*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7366*4bdc9457SAndroid Build Coastguard Worker }
7367*4bdc9457SAndroid Build Coastguard Worker
7368*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s2_with_tf_same_padding) {
7369*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
7370*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
7371*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7372*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7373*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7374*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7375*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7376*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7377*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7378*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7379*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7380*4bdc9457SAndroid Build Coastguard Worker }
7381*4bdc9457SAndroid Build Coastguard Worker }
7382*4bdc9457SAndroid Build Coastguard Worker }
7383*4bdc9457SAndroid Build Coastguard Worker
7384*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s1x2) {
7385*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7386*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
7387*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7388*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7389*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7390*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7391*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7392*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7393*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7394*4bdc9457SAndroid Build Coastguard Worker }
7395*4bdc9457SAndroid Build Coastguard Worker
7396*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s1x2_with_tf_same_padding) {
7397*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
7398*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
7399*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7400*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7401*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7402*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7403*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7404*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7405*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7406*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7407*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7408*4bdc9457SAndroid Build Coastguard Worker }
7409*4bdc9457SAndroid Build Coastguard Worker }
7410*4bdc9457SAndroid Build Coastguard Worker }
7411*4bdc9457SAndroid Build Coastguard Worker
7412*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s2x1) {
7413*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7414*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 13)
7415*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7416*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7417*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7418*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7419*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7420*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7421*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7422*4bdc9457SAndroid Build Coastguard Worker }
7423*4bdc9457SAndroid Build Coastguard Worker
7424*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3s2x1_with_tf_same_padding) {
7425*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 13; input_height <= 14; input_height++) {
7426*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 13; input_width <= 14; input_width++) {
7427*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7428*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7429*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7430*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7431*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7432*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7433*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7434*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7435*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7436*4bdc9457SAndroid Build Coastguard Worker }
7437*4bdc9457SAndroid Build Coastguard Worker }
7438*4bdc9457SAndroid Build Coastguard Worker }
7439*4bdc9457SAndroid Build Coastguard Worker
7440*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3d2) {
7441*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7442*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 14)
7443*4bdc9457SAndroid Build Coastguard Worker .padding(2)
7444*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7445*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
7446*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7447*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7448*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7449*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7450*4bdc9457SAndroid Build Coastguard Worker }
7451*4bdc9457SAndroid Build Coastguard Worker
7452*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3d1x2) {
7453*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7454*4bdc9457SAndroid Build Coastguard Worker .input_size(14, 15)
7455*4bdc9457SAndroid Build Coastguard Worker .padding(1, 2)
7456*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7457*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
7458*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7459*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7460*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7461*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7462*4bdc9457SAndroid Build Coastguard Worker }
7463*4bdc9457SAndroid Build Coastguard Worker
7464*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, 3x3d2x1) {
7465*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7466*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7467*4bdc9457SAndroid Build Coastguard Worker .padding(2, 1)
7468*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7469*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
7470*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(27)
7471*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7472*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7473*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7474*4bdc9457SAndroid Build Coastguard Worker }
7475*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_3x3)7476*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_3x3) {
7477*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7478*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7479*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7480*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7481*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7482*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7483*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7484*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7485*4bdc9457SAndroid Build Coastguard Worker }
7486*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_3x3_with_qmin)7487*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_3x3_with_qmin) {
7488*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7489*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7490*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7491*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7492*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7493*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7494*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
7495*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7496*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7497*4bdc9457SAndroid Build Coastguard Worker }
7498*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_3x3_with_qmax)7499*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_3x3_with_qmax) {
7500*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7501*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7502*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7503*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7504*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7505*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7506*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
7507*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7508*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7509*4bdc9457SAndroid Build Coastguard Worker }
7510*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_3x3_with_input_stride)7511*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_3x3_with_input_stride) {
7512*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7513*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7514*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7515*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7516*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(28)
7517*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7518*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7519*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7520*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7521*4bdc9457SAndroid Build Coastguard Worker }
7522*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_3x3_with_output_stride)7523*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_3x3_with_output_stride) {
7524*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7525*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7526*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7527*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7528*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(29)
7529*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7530*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7531*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7532*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7533*4bdc9457SAndroid Build Coastguard Worker }
7534*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_3x3)7535*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_3x3) {
7536*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7537*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7538*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7539*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7540*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7541*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7542*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7543*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7544*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7545*4bdc9457SAndroid Build Coastguard Worker }
7546*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_3x3_with_qmin)7547*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_3x3_with_qmin) {
7548*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7549*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7550*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7551*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7552*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7553*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7554*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7555*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
7556*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7557*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7558*4bdc9457SAndroid Build Coastguard Worker }
7559*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_3x3_with_qmax)7560*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_3x3_with_qmax) {
7561*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7562*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7563*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7564*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7565*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7566*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7567*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7568*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
7569*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7570*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7571*4bdc9457SAndroid Build Coastguard Worker }
7572*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_3x3_with_input_stride)7573*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_3x3_with_input_stride) {
7574*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7575*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7576*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7577*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7578*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7579*4bdc9457SAndroid Build Coastguard Worker .input_channel_stride(37)
7580*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7581*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7582*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7583*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7584*4bdc9457SAndroid Build Coastguard Worker }
7585*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,unioutput_grouped_3x3_with_output_stride)7586*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, unioutput_grouped_3x3_with_output_stride) {
7587*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7588*4bdc9457SAndroid Build Coastguard Worker .input_size(3, 3)
7589*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7590*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7591*4bdc9457SAndroid Build Coastguard Worker .groups(2)
7592*4bdc9457SAndroid Build Coastguard Worker .output_channel_stride(41)
7593*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(17)
7594*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(13)
7595*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7596*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7597*4bdc9457SAndroid Build Coastguard Worker }
7598*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_1x1)7599*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_1x1) {
7600*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7601*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7602*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7603*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7604*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7605*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7606*4bdc9457SAndroid Build Coastguard Worker }
7607*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_1x1_with_fp32_weights)7608*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_1x1_with_fp32_weights) {
7609*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7610*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
7611*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7612*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7613*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7614*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7615*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7616*4bdc9457SAndroid Build Coastguard Worker }
7617*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_1x1_without_bias)7618*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_1x1_without_bias) {
7619*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7620*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7621*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7622*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7623*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7624*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7625*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7626*4bdc9457SAndroid Build Coastguard Worker }
7627*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2)7628*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2) {
7629*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7630*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7631*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7632*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7633*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7634*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7635*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7636*4bdc9457SAndroid Build Coastguard Worker }
7637*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2_without_bias)7638*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2_without_bias) {
7639*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7640*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7641*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7642*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7643*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7644*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7645*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7646*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7647*4bdc9457SAndroid Build Coastguard Worker }
7648*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2s2)7649*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2s2) {
7650*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7651*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7652*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7653*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7654*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7655*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7656*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7657*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7658*4bdc9457SAndroid Build Coastguard Worker }
7659*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2s1x2)7660*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2s1x2) {
7661*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7662*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7663*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7664*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7665*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7666*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7667*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7668*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7669*4bdc9457SAndroid Build Coastguard Worker }
7670*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2s2x1)7671*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2s2x1) {
7672*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7673*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7674*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7675*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7676*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7677*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7678*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7679*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7680*4bdc9457SAndroid Build Coastguard Worker }
7681*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2d2)7682*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2d2) {
7683*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7684*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7685*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7686*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7687*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
7688*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7689*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7690*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7691*4bdc9457SAndroid Build Coastguard Worker }
7692*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2d1x2)7693*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2d1x2) {
7694*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7695*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7696*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7697*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7698*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
7699*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7700*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7701*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7702*4bdc9457SAndroid Build Coastguard Worker }
7703*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_2x2d2x1)7704*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_2x2d2x1) {
7705*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7706*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7707*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7708*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7709*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
7710*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7711*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7712*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7713*4bdc9457SAndroid Build Coastguard Worker }
7714*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3)7715*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3) {
7716*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7717*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7718*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7719*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7720*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7721*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7722*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7723*4bdc9457SAndroid Build Coastguard Worker }
7724*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3_with_fp32_weights)7725*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3_with_fp32_weights) {
7726*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7727*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
7728*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7729*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7730*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7731*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7732*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7733*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7734*4bdc9457SAndroid Build Coastguard Worker }
7735*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3_without_bias)7736*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3_without_bias) {
7737*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7738*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7739*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7740*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7741*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7742*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7743*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7744*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7745*4bdc9457SAndroid Build Coastguard Worker }
7746*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s2)7747*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s2) {
7748*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7749*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7750*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7751*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7752*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7753*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7754*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7755*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7756*4bdc9457SAndroid Build Coastguard Worker }
7757*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s2_with_tf_same_padding)7758*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s2_with_tf_same_padding) {
7759*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
7760*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
7761*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7762*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7763*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7764*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7765*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7766*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7767*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7768*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7769*4bdc9457SAndroid Build Coastguard Worker }
7770*4bdc9457SAndroid Build Coastguard Worker }
7771*4bdc9457SAndroid Build Coastguard Worker }
7772*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s1x2)7773*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s1x2) {
7774*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7775*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7776*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7777*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7778*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7779*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7780*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7781*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7782*4bdc9457SAndroid Build Coastguard Worker }
7783*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s1x2_with_tf_same_padding)7784*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s1x2_with_tf_same_padding) {
7785*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
7786*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
7787*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7788*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7789*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7790*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7791*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7792*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7793*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7794*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7795*4bdc9457SAndroid Build Coastguard Worker }
7796*4bdc9457SAndroid Build Coastguard Worker }
7797*4bdc9457SAndroid Build Coastguard Worker }
7798*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s2x1)7799*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s2x1) {
7800*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7801*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7802*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7803*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7804*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7805*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7806*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7807*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7808*4bdc9457SAndroid Build Coastguard Worker }
7809*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3s2x1_with_tf_same_padding)7810*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3s2x1_with_tf_same_padding) {
7811*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
7812*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
7813*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7814*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
7815*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
7816*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7817*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7818*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7819*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7820*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7821*4bdc9457SAndroid Build Coastguard Worker }
7822*4bdc9457SAndroid Build Coastguard Worker }
7823*4bdc9457SAndroid Build Coastguard Worker }
7824*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3d2)7825*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3d2) {
7826*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7827*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7828*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7829*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7830*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
7831*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7832*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7833*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7834*4bdc9457SAndroid Build Coastguard Worker }
7835*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3d1x2)7836*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3d1x2) {
7837*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7838*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7839*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7840*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7841*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
7842*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7843*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7844*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7845*4bdc9457SAndroid Build Coastguard Worker }
7846*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_3x3d2x1)7847*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_3x3d2x1) {
7848*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7849*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7850*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7851*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7852*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
7853*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7854*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7855*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7856*4bdc9457SAndroid Build Coastguard Worker }
7857*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5)7858*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5) {
7859*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7860*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7861*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7862*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7863*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7864*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7865*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7866*4bdc9457SAndroid Build Coastguard Worker }
7867*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5_without_bias)7868*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5_without_bias) {
7869*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7870*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
7871*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7872*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7873*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7874*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7875*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7876*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7877*4bdc9457SAndroid Build Coastguard Worker }
7878*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5s2)7879*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5s2) {
7880*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7881*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7882*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7883*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7884*4bdc9457SAndroid Build Coastguard Worker .subsampling(2)
7885*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7886*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7887*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7888*4bdc9457SAndroid Build Coastguard Worker }
7889*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5s1x2)7890*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5s1x2) {
7891*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7892*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7893*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7894*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7895*4bdc9457SAndroid Build Coastguard Worker .subsampling(1, 2)
7896*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7897*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7898*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7899*4bdc9457SAndroid Build Coastguard Worker }
7900*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5s2x1)7901*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5s2x1) {
7902*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7903*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7904*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7905*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7906*4bdc9457SAndroid Build Coastguard Worker .subsampling(2, 1)
7907*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7908*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7909*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7910*4bdc9457SAndroid Build Coastguard Worker }
7911*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5d2)7912*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5d2) {
7913*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7914*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7915*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7916*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7917*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
7918*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7919*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7920*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7921*4bdc9457SAndroid Build Coastguard Worker }
7922*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5d1x2)7923*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5d1x2) {
7924*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7925*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7926*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7927*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7928*4bdc9457SAndroid Build Coastguard Worker .dilation(1, 2)
7929*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7930*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7931*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7932*4bdc9457SAndroid Build Coastguard Worker }
7933*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,depthwise_5x5d2x1)7934*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, depthwise_5x5d2x1) {
7935*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7936*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7937*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
7938*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
7939*4bdc9457SAndroid Build Coastguard Worker .dilation(2, 1)
7940*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7941*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7942*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7943*4bdc9457SAndroid Build Coastguard Worker }
7944*4bdc9457SAndroid Build Coastguard Worker
7945*4bdc9457SAndroid Build Coastguard Worker // Tests GEMM microkernel with weights_cache.
TEST(CONVOLUTION_NHWC_F16,weights_cache_1x1)7946*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, weights_cache_1x1) {
7947*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7948*4bdc9457SAndroid Build Coastguard Worker .input_size(27, 29)
7949*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7950*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(23)
7951*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(19)
7952*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
7953*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7954*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7955*4bdc9457SAndroid Build Coastguard Worker }
7956*4bdc9457SAndroid Build Coastguard Worker
7957*4bdc9457SAndroid Build Coastguard Worker // Tests IGEMM microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F16,weights_cache_3x3)7958*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, weights_cache_3x3) {
7959*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7960*4bdc9457SAndroid Build Coastguard Worker .input_size(13, 12)
7961*4bdc9457SAndroid Build Coastguard Worker .padding(1)
7962*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
7963*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
7964*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
7965*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
7966*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7967*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7968*4bdc9457SAndroid Build Coastguard Worker }
7969*4bdc9457SAndroid Build Coastguard Worker
7970*4bdc9457SAndroid Build Coastguard Worker // Tests vmulcaddc microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F16,weights_cache_depthwise_1x1)7971*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, weights_cache_depthwise_1x1) {
7972*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7973*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7974*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7975*4bdc9457SAndroid Build Coastguard Worker .groups(24)
7976*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
7977*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7978*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7979*4bdc9457SAndroid Build Coastguard Worker }
7980*4bdc9457SAndroid Build Coastguard Worker
7981*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(CONVOLUTION_NHWC_F16,weights_cache_depthwise_2x2d2)7982*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, weights_cache_depthwise_2x2d2) {
7983*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7984*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7985*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
7986*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
7987*4bdc9457SAndroid Build Coastguard Worker .dilation(2)
7988*4bdc9457SAndroid Build Coastguard Worker .groups(27)
7989*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
7990*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
7991*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
7992*4bdc9457SAndroid Build Coastguard Worker }
7993*4bdc9457SAndroid Build Coastguard Worker
7994*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 1x1) {
7995*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
7996*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
7997*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
7998*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
7999*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8000*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8001*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8002*4bdc9457SAndroid Build Coastguard Worker }
8003*4bdc9457SAndroid Build Coastguard Worker
8004*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 1x1_with_fp32_weights) {
8005*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8006*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
8007*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8008*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8009*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
8010*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8011*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8012*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8013*4bdc9457SAndroid Build Coastguard Worker }
8014*4bdc9457SAndroid Build Coastguard Worker
8015*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 1x1_with_depth_multiplier) {
8016*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8017*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8018*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8019*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
8020*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8021*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8022*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8023*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8024*4bdc9457SAndroid Build Coastguard Worker }
8025*4bdc9457SAndroid Build Coastguard Worker
8026*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 1x1_with_depth_multiplier_with_fp32_weights) {
8027*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8028*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
8029*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8030*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8031*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
8032*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8033*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8034*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8035*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8036*4bdc9457SAndroid Build Coastguard Worker }
8037*4bdc9457SAndroid Build Coastguard Worker
8038*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 1x1_without_bias) {
8039*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8040*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8041*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
8042*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8043*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
8044*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8045*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8046*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8047*4bdc9457SAndroid Build Coastguard Worker }
8048*4bdc9457SAndroid Build Coastguard Worker
8049*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 2x2) {
8050*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8051*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8052*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8053*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8054*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
8055*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8056*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8057*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8058*4bdc9457SAndroid Build Coastguard Worker }
8059*4bdc9457SAndroid Build Coastguard Worker
8060*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 2x2_with_depth_multiplier) {
8061*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8062*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8063*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8064*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8065*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
8066*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8067*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8068*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8069*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8070*4bdc9457SAndroid Build Coastguard Worker }
8071*4bdc9457SAndroid Build Coastguard Worker
8072*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 2x2_without_bias) {
8073*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8074*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8075*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
8076*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8077*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8078*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
8079*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8080*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8081*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8082*4bdc9457SAndroid Build Coastguard Worker }
8083*4bdc9457SAndroid Build Coastguard Worker
8084*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3) {
8085*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8086*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8087*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8088*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8089*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8090*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8091*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8092*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8093*4bdc9457SAndroid Build Coastguard Worker }
8094*4bdc9457SAndroid Build Coastguard Worker
8095*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3_weight_fp32_weights) {
8096*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8097*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
8098*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8099*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8100*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8101*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8102*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8103*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8104*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8105*4bdc9457SAndroid Build Coastguard Worker }
8106*4bdc9457SAndroid Build Coastguard Worker
8107*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3_with_depth_multiplier) {
8108*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8109*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8110*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8111*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8112*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8113*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8114*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8115*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8116*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8117*4bdc9457SAndroid Build Coastguard Worker }
8118*4bdc9457SAndroid Build Coastguard Worker
8119*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3_with_depth_multiplier_with_fp32_weights) {
8120*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8121*4bdc9457SAndroid Build Coastguard Worker .weights_type(ConvolutionOperatorTester::WeightsType::FP32)
8122*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8123*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8124*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8125*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8126*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8127*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8128*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8129*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8130*4bdc9457SAndroid Build Coastguard Worker }
8131*4bdc9457SAndroid Build Coastguard Worker
8132*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3_without_bias) {
8133*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8134*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8135*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
8136*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8137*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8138*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8139*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8140*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8141*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8142*4bdc9457SAndroid Build Coastguard Worker }
8143*4bdc9457SAndroid Build Coastguard Worker
8144*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 3x3s2_with_tf_same_padding) {
8145*4bdc9457SAndroid Build Coastguard Worker for (size_t input_height = 14; input_height <= 15; input_height++) {
8146*4bdc9457SAndroid Build Coastguard Worker for (size_t input_width = 14; input_width <= 15; input_width++) {
8147*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8148*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8149*4bdc9457SAndroid Build Coastguard Worker .input_size(input_height, input_width)
8150*4bdc9457SAndroid Build Coastguard Worker .padding_tf_same(true)
8151*4bdc9457SAndroid Build Coastguard Worker .kernel_size(3, 3)
8152*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8153*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8154*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8155*4bdc9457SAndroid Build Coastguard Worker }
8156*4bdc9457SAndroid Build Coastguard Worker }
8157*4bdc9457SAndroid Build Coastguard Worker }
8158*4bdc9457SAndroid Build Coastguard Worker
8159*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 5x5) {
8160*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8161*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8162*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8163*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
8164*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
8165*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8166*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8167*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8168*4bdc9457SAndroid Build Coastguard Worker }
8169*4bdc9457SAndroid Build Coastguard Worker
8170*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 5x5_with_depth_multiplier) {
8171*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8172*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8173*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8174*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
8175*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
8176*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8177*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(3)
8178*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8179*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8180*4bdc9457SAndroid Build Coastguard Worker }
8181*4bdc9457SAndroid Build Coastguard Worker
8182*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 5x5_without_bias) {
8183*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8184*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8185*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
8186*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8187*4bdc9457SAndroid Build Coastguard Worker .padding(2, 2)
8188*4bdc9457SAndroid Build Coastguard Worker .kernel_size(5, 5)
8189*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8190*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8191*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8192*4bdc9457SAndroid Build Coastguard Worker }
8193*4bdc9457SAndroid Build Coastguard Worker
8194*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 7x7) {
8195*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8196*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8197*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8198*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
8199*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
8200*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8201*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8202*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8203*4bdc9457SAndroid Build Coastguard Worker }
8204*4bdc9457SAndroid Build Coastguard Worker
8205*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, 7x7_without_bias) {
8206*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8207*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8208*4bdc9457SAndroid Build Coastguard Worker .has_bias(false)
8209*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8210*4bdc9457SAndroid Build Coastguard Worker .padding(3, 3)
8211*4bdc9457SAndroid Build Coastguard Worker .kernel_size(7, 7)
8212*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8213*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8214*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8215*4bdc9457SAndroid Build Coastguard Worker }
8216*4bdc9457SAndroid Build Coastguard Worker
8217*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernel with weights cache.
TEST(DEPTHWISE_CONVOLUTION_NHWC_F16,weights_cache_1x1)8218*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, weights_cache_1x1) {
8219*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8220*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8221*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8222*4bdc9457SAndroid Build Coastguard Worker .kernel_size(1, 1)
8223*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8224*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
8225*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8226*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8227*4bdc9457SAndroid Build Coastguard Worker }
8228*4bdc9457SAndroid Build Coastguard Worker
8229*4bdc9457SAndroid Build Coastguard Worker // Tests dwconv microkernek with non 1x1 kernel (dwconv_hwg packing).
TEST(DEPTHWISE_CONVOLUTION_NHWC_F16,weights_cache_2x2)8230*4bdc9457SAndroid Build Coastguard Worker TEST(DEPTHWISE_CONVOLUTION_NHWC_F16, weights_cache_2x2) {
8231*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8232*4bdc9457SAndroid Build Coastguard Worker .depthwise_layout(true)
8233*4bdc9457SAndroid Build Coastguard Worker .input_size(15, 14)
8234*4bdc9457SAndroid Build Coastguard Worker .padding(1, 1)
8235*4bdc9457SAndroid Build Coastguard Worker .kernel_size(2, 2)
8236*4bdc9457SAndroid Build Coastguard Worker .groups(24)
8237*4bdc9457SAndroid Build Coastguard Worker .use_weights_cache(true)
8238*4bdc9457SAndroid Build Coastguard Worker .iterations(3)
8239*4bdc9457SAndroid Build Coastguard Worker .TestNHWCxF16();
8240*4bdc9457SAndroid Build Coastguard Worker }
8241*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_input_buffer)8242*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_input_buffer) {
8243*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8244*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8245*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8246*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8247*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8248*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8249*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8250*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8251*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8252*4bdc9457SAndroid Build Coastguard Worker }
8253*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_input_buffer_grouped)8254*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_input_buffer_grouped) {
8255*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8256*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8257*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8258*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8259*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8260*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8261*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8262*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8263*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8264*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8265*4bdc9457SAndroid Build Coastguard Worker }
8266*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_input_buffer_depthwise)8267*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_input_buffer_depthwise) {
8268*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8269*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8270*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8271*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8272*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8273*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8274*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8275*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8276*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8277*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8278*4bdc9457SAndroid Build Coastguard Worker }
8279*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_increasing_batch)8280*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_increasing_batch) {
8281*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8282*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8283*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
8284*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8285*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8286*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8287*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8288*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8289*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8290*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8291*4bdc9457SAndroid Build Coastguard Worker }
8292*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_increasing_batch_grouped)8293*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_increasing_batch_grouped) {
8294*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8295*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8296*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
8297*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8298*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8299*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8300*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8301*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8302*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8303*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8304*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8305*4bdc9457SAndroid Build Coastguard Worker }
8306*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_increasing_batch_depthwise)8307*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_increasing_batch_depthwise) {
8308*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8309*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8310*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(5)
8311*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8312*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8313*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8314*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8315*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8316*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8317*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8318*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8319*4bdc9457SAndroid Build Coastguard Worker }
8320*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_decreasing_batch)8321*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_decreasing_batch) {
8322*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8323*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
8324*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
8325*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8326*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8327*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8328*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8329*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8330*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8331*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8332*4bdc9457SAndroid Build Coastguard Worker }
8333*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_decreasing_batch_grouped)8334*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_decreasing_batch_grouped) {
8335*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8336*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
8337*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
8338*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8339*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8340*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8341*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8342*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8343*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8344*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8345*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8346*4bdc9457SAndroid Build Coastguard Worker }
8347*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_decreasing_batch_depthwise)8348*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_decreasing_batch_depthwise) {
8349*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8350*4bdc9457SAndroid Build Coastguard Worker .batch_size(5)
8351*4bdc9457SAndroid Build Coastguard Worker .next_batch_size(3)
8352*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8353*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8354*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8355*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8356*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8357*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8358*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8359*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8360*4bdc9457SAndroid Build Coastguard Worker }
8361*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_height)8362*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_height) {
8363*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8364*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8365*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8366*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8367*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
8368*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8369*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8370*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8371*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8372*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8373*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8374*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8375*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8376*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8377*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
8378*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8379*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8380*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8381*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8382*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8383*4bdc9457SAndroid Build Coastguard Worker }
8384*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_height_grouped)8385*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_height_grouped) {
8386*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8387*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8388*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8389*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8390*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
8391*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8392*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8393*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8394*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8395*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8396*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8397*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8398*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8399*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8400*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8401*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
8402*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8403*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8404*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8405*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8406*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8407*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8408*4bdc9457SAndroid Build Coastguard Worker }
8409*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_height_depthwise)8410*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_height_depthwise) {
8411*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8412*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8413*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8414*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8415*4bdc9457SAndroid Build Coastguard Worker .next_input_height(9)
8416*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8417*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8418*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8419*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8420*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8421*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8422*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8423*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8424*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8425*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8426*4bdc9457SAndroid Build Coastguard Worker .next_input_height(7)
8427*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8428*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8429*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8430*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8431*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8432*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8433*4bdc9457SAndroid Build Coastguard Worker }
8434*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_width)8435*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_width) {
8436*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8437*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8438*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8439*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8440*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8441*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8442*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8443*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8444*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8445*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8446*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8447*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8448*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8449*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8450*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
8451*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8452*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8453*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8454*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8455*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8456*4bdc9457SAndroid Build Coastguard Worker }
8457*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_width_grouped)8458*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_width_grouped) {
8459*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8460*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8461*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8462*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8463*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8464*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8465*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8466*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8467*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8468*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8469*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8470*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8471*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8472*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8473*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8474*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
8475*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8476*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8477*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8478*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8479*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8480*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8481*4bdc9457SAndroid Build Coastguard Worker }
8482*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_changing_width_depthwise)8483*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_changing_width_depthwise) {
8484*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8485*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8486*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8487*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8488*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8489*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8490*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8491*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8492*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8493*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8494*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8495*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8496*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8497*4bdc9457SAndroid Build Coastguard Worker .input_height(8)
8498*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8499*4bdc9457SAndroid Build Coastguard Worker .next_input_width(7)
8500*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8501*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8502*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8503*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8504*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8505*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8506*4bdc9457SAndroid Build Coastguard Worker }
8507*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_swap_height_and_width)8508*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_swap_height_and_width) {
8509*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8510*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8511*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
8512*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8513*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
8514*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8515*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8516*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8517*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8518*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8519*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8520*4bdc9457SAndroid Build Coastguard Worker }
8521*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_swap_height_and_width_grouped)8522*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_swap_height_and_width_grouped) {
8523*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8524*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8525*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
8526*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8527*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
8528*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8529*4bdc9457SAndroid Build Coastguard Worker .kernel_height(5)
8530*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8531*4bdc9457SAndroid Build Coastguard Worker .groups(2)
8532*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(15)
8533*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(17)
8534*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8535*4bdc9457SAndroid Build Coastguard Worker }
8536*4bdc9457SAndroid Build Coastguard Worker
TEST(CONVOLUTION_NHWC_F16,setup_swap_height_and_width_depthwise)8537*4bdc9457SAndroid Build Coastguard Worker TEST(CONVOLUTION_NHWC_F16, setup_swap_height_and_width_depthwise) {
8538*4bdc9457SAndroid Build Coastguard Worker ConvolutionOperatorTester()
8539*4bdc9457SAndroid Build Coastguard Worker .batch_size(3)
8540*4bdc9457SAndroid Build Coastguard Worker .input_height(9)
8541*4bdc9457SAndroid Build Coastguard Worker .input_width(8)
8542*4bdc9457SAndroid Build Coastguard Worker .next_input_height(8)
8543*4bdc9457SAndroid Build Coastguard Worker .next_input_width(9)
8544*4bdc9457SAndroid Build Coastguard Worker .kernel_height(3)
8545*4bdc9457SAndroid Build Coastguard Worker .kernel_width(3)
8546*4bdc9457SAndroid Build Coastguard Worker .groups(19)
8547*4bdc9457SAndroid Build Coastguard Worker .group_input_channels(1)
8548*4bdc9457SAndroid Build Coastguard Worker .group_output_channels(1)
8549*4bdc9457SAndroid Build Coastguard Worker .TestSetupNHWCxF16();
8550*4bdc9457SAndroid Build Coastguard Worker }
8551