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