1*4bdc9457SAndroid Build Coastguard Worker // Copyright 2021 Google LLC
2*4bdc9457SAndroid Build Coastguard Worker //
3*4bdc9457SAndroid Build Coastguard Worker // This source code is licensed under the BSD-style license found in the
4*4bdc9457SAndroid Build Coastguard Worker // LICENSE file in the root directory of this source tree.
5*4bdc9457SAndroid Build Coastguard Worker //
6*4bdc9457SAndroid Build Coastguard Worker // Auto-generated file. Do not edit!
7*4bdc9457SAndroid Build Coastguard Worker // Specification: test/x32-transpose.yaml
8*4bdc9457SAndroid Build Coastguard Worker // Generator: tools/generate-transpose-test.py
9*4bdc9457SAndroid Build Coastguard Worker
10*4bdc9457SAndroid Build Coastguard Worker
11*4bdc9457SAndroid Build Coastguard Worker #include <gtest/gtest.h>
12*4bdc9457SAndroid Build Coastguard Worker
13*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/common.h>
14*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/isa-checks.h>
15*4bdc9457SAndroid Build Coastguard Worker
16*4bdc9457SAndroid Build Coastguard Worker #include <xnnpack/transpose.h>
17*4bdc9457SAndroid Build Coastguard Worker #include "transpose-microkernel-tester.h"
18*4bdc9457SAndroid Build Coastguard Worker
19*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_2)20*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_2) {
21*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
22*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
23*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
24*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
25*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
26*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
27*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
28*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
29*4bdc9457SAndroid Build Coastguard Worker }
30*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_2_bw_1_4)31*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_2_bw_1_4) {
32*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 2; ++i){
33*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
34*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
35*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
36*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
37*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
38*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
39*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
40*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
41*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
42*4bdc9457SAndroid Build Coastguard Worker }
43*4bdc9457SAndroid Build Coastguard Worker }
44*4bdc9457SAndroid Build Coastguard Worker }
45*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_4)46*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_4) {
47*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
48*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
49*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
50*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
51*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
52*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
53*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
54*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
55*4bdc9457SAndroid Build Coastguard Worker }
56*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_3_4)57*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_3_4) {
58*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
59*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
60*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
61*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
62*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
63*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
64*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
65*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
66*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
67*4bdc9457SAndroid Build Coastguard Worker }
68*4bdc9457SAndroid Build Coastguard Worker }
69*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_2_bw_3_4)70*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_2_bw_3_4) {
71*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
72*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
73*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
74*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
75*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
76*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
77*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
78*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
79*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
80*4bdc9457SAndroid Build Coastguard Worker }
81*4bdc9457SAndroid Build Coastguard Worker }
82*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_2_bw_2)83*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_2_bw_2) {
84*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
85*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
86*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
87*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
88*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
89*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
90*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
91*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
92*4bdc9457SAndroid Build Coastguard Worker }
93*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_2_2_bw_2)94*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_2_2_bw_2){
95*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
96*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
97*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
98*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
99*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
100*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
101*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
102*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
103*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
104*4bdc9457SAndroid Build Coastguard Worker }
105*4bdc9457SAndroid Build Coastguard Worker }
106*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_2_2_bw_4)107*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_2_2_bw_4){
108*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
109*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
110*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
111*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
112*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
113*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
114*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
115*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
116*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
117*4bdc9457SAndroid Build Coastguard Worker }
118*4bdc9457SAndroid Build Coastguard Worker }
119*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_2_2_bw_3_4)120*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_2_2_bw_3_4) {
121*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
122*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
123*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
124*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
125*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
126*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
127*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
128*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
129*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
130*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
131*4bdc9457SAndroid Build Coastguard Worker }
132*4bdc9457SAndroid Build Coastguard Worker }
133*4bdc9457SAndroid Build Coastguard Worker }
134*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_2_is_4)135*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_2_is_4) {
136*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
137*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
138*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
139*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
140*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
141*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
142*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
143*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
144*4bdc9457SAndroid Build Coastguard Worker }
145*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_2_os_2)146*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_2_os_2) {
147*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
148*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
149*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
150*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
151*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
152*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
153*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
155*4bdc9457SAndroid Build Coastguard Worker }
156*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_1_bw_2_is_4_os_2)157*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_1_bw_2_is_4_os_2) {
158*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
159*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
160*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
161*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
162*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
163*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
164*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
166*4bdc9457SAndroid Build Coastguard Worker }
167*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_17_bw_38_ies_15)168*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_17_bw_38_ies_15) {
169*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
170*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
171*4bdc9457SAndroid Build Coastguard Worker .output_stride(17)
172*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
173*4bdc9457SAndroid Build Coastguard Worker .block_height(17)
174*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
175*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
176*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
178*4bdc9457SAndroid Build Coastguard Worker }
179*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_3_bw_10_oes_15)180*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_3_bw_10_oes_15) {
181*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
182*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
183*4bdc9457SAndroid Build Coastguard Worker .output_stride(3)
184*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
185*4bdc9457SAndroid Build Coastguard Worker .block_height(3)
186*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
187*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
190*4bdc9457SAndroid Build Coastguard Worker }
191*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4,bh_7_bw_46_ies_21_oes_17)192*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_FLOAT_4, bh_7_bw_46_ies_21_oes_17) {
193*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
194*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
195*4bdc9457SAndroid Build Coastguard Worker .output_stride(13)
196*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
197*4bdc9457SAndroid Build Coastguard Worker .block_height(7)
198*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
199*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
200*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
201*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
202*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_float);
203*4bdc9457SAndroid Build Coastguard Worker }
204*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_2)205*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_2) {
206*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
207*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
208*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
209*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
210*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
211*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
214*4bdc9457SAndroid Build Coastguard Worker }
215*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_2_bw_1_4)216*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_2_bw_1_4) {
217*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 2; ++i){
218*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
219*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
220*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
221*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
222*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
223*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
224*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
227*4bdc9457SAndroid Build Coastguard Worker }
228*4bdc9457SAndroid Build Coastguard Worker }
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_4)231*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_4) {
232*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
233*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
234*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
235*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
236*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
237*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
238*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
239*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
240*4bdc9457SAndroid Build Coastguard Worker }
241*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_3_4)242*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_3_4) {
243*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
244*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
245*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
246*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
247*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
248*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
249*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
250*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
251*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
252*4bdc9457SAndroid Build Coastguard Worker }
253*4bdc9457SAndroid Build Coastguard Worker }
254*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_2_bw_3_4)255*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_2_bw_3_4) {
256*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
257*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
258*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
259*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
260*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
261*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
262*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
265*4bdc9457SAndroid Build Coastguard Worker }
266*4bdc9457SAndroid Build Coastguard Worker }
267*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_2_bw_2)268*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_2_bw_2) {
269*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
270*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
271*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
272*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
273*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
274*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
275*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
276*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
277*4bdc9457SAndroid Build Coastguard Worker }
278*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_2_2_bw_2)279*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_2_2_bw_2){
280*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
281*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
282*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
283*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
284*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
285*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
286*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
287*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
288*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
289*4bdc9457SAndroid Build Coastguard Worker }
290*4bdc9457SAndroid Build Coastguard Worker }
291*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_2_2_bw_4)292*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_2_2_bw_4){
293*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
294*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
295*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
296*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
297*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
298*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
299*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
300*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
301*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
302*4bdc9457SAndroid Build Coastguard Worker }
303*4bdc9457SAndroid Build Coastguard Worker }
304*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_2_2_bw_3_4)305*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_2_2_bw_3_4) {
306*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
307*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
308*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
309*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
310*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
311*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
312*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
313*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
314*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
315*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
316*4bdc9457SAndroid Build Coastguard Worker }
317*4bdc9457SAndroid Build Coastguard Worker }
318*4bdc9457SAndroid Build Coastguard Worker }
319*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_2_is_4)320*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_2_is_4) {
321*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
322*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
323*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
324*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
325*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
326*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
327*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
328*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
329*4bdc9457SAndroid Build Coastguard Worker }
330*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_2_os_2)331*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_2_os_2) {
332*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
333*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
334*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
335*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
336*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
337*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
338*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
339*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
340*4bdc9457SAndroid Build Coastguard Worker }
341*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_1_bw_2_is_4_os_2)342*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_1_bw_2_is_4_os_2) {
343*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
344*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
345*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
346*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
347*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
348*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
351*4bdc9457SAndroid Build Coastguard Worker }
352*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_17_bw_38_ies_15)353*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_17_bw_38_ies_15) {
354*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
355*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
356*4bdc9457SAndroid Build Coastguard Worker .output_stride(17)
357*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
358*4bdc9457SAndroid Build Coastguard Worker .block_height(17)
359*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
360*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
361*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
362*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
363*4bdc9457SAndroid Build Coastguard Worker }
364*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_3_bw_10_oes_15)365*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_3_bw_10_oes_15) {
366*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
367*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
368*4bdc9457SAndroid Build Coastguard Worker .output_stride(3)
369*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
370*4bdc9457SAndroid Build Coastguard Worker .block_height(3)
371*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
372*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
375*4bdc9457SAndroid Build Coastguard Worker }
376*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4,bh_7_bw_46_ies_21_oes_17)377*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X2_SCALAR_INT_4, bh_7_bw_46_ies_21_oes_17) {
378*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
379*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
380*4bdc9457SAndroid Build Coastguard Worker .output_stride(13)
381*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
382*4bdc9457SAndroid Build Coastguard Worker .block_height(7)
383*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
384*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
385*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
386*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
387*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x2_scalar_int);
388*4bdc9457SAndroid Build Coastguard Worker }
389*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_4)390*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_4) {
391*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
392*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
393*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
394*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
395*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
396*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
399*4bdc9457SAndroid Build Coastguard Worker }
400*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_2_bw_1_8)401*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_2_bw_1_8) {
402*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 2; ++i){
403*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
404*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
405*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
406*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
407*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
408*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
409*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
412*4bdc9457SAndroid Build Coastguard Worker }
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker }
415*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_8)416*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_8) {
417*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
418*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
419*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
420*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
421*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
422*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
423*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
424*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
425*4bdc9457SAndroid Build Coastguard Worker }
426*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_5_8)427*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_5_8) {
428*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
429*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
430*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
431*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
432*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
433*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
434*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
435*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
436*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
437*4bdc9457SAndroid Build Coastguard Worker }
438*4bdc9457SAndroid Build Coastguard Worker }
439*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_2_bw_5_8)440*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_2_bw_5_8) {
441*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
442*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
443*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
444*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
445*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
446*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
447*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
450*4bdc9457SAndroid Build Coastguard Worker }
451*4bdc9457SAndroid Build Coastguard Worker }
452*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_2_bw_4)453*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_2_bw_4) {
454*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
455*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
456*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
457*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
458*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
459*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
460*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
461*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
462*4bdc9457SAndroid Build Coastguard Worker }
463*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_2_2_bw_4)464*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_2_2_bw_4){
465*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
466*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
467*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
468*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
469*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
470*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
471*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
472*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
473*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
474*4bdc9457SAndroid Build Coastguard Worker }
475*4bdc9457SAndroid Build Coastguard Worker }
476*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_2_2_bw_8)477*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_2_2_bw_8){
478*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
479*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
480*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
481*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
482*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
483*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
484*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
485*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
486*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
487*4bdc9457SAndroid Build Coastguard Worker }
488*4bdc9457SAndroid Build Coastguard Worker }
489*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_2_2_bw_5_8)490*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_2_2_bw_5_8) {
491*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
492*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
493*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
494*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
495*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
496*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
497*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
498*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
499*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
500*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
501*4bdc9457SAndroid Build Coastguard Worker }
502*4bdc9457SAndroid Build Coastguard Worker }
503*4bdc9457SAndroid Build Coastguard Worker }
504*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_4_is_8)505*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_4_is_8) {
506*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
507*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
508*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
509*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
510*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
511*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
512*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
513*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
514*4bdc9457SAndroid Build Coastguard Worker }
515*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_4_os_2)516*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_4_os_2) {
517*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
518*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
519*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
520*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
521*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
522*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_1_bw_4_is_8_os_2)527*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_1_bw_4_is_8_os_2) {
528*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
529*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
530*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
531*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
532*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
533*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
536*4bdc9457SAndroid Build Coastguard Worker }
537*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_17_bw_76_ies_15)538*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_17_bw_76_ies_15) {
539*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
540*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
541*4bdc9457SAndroid Build Coastguard Worker .output_stride(17)
542*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
543*4bdc9457SAndroid Build Coastguard Worker .block_height(17)
544*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
545*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
546*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
547*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
548*4bdc9457SAndroid Build Coastguard Worker }
549*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_3_bw_20_oes_15)550*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_3_bw_20_oes_15) {
551*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
552*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
553*4bdc9457SAndroid Build Coastguard Worker .output_stride(3)
554*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
555*4bdc9457SAndroid Build Coastguard Worker .block_height(3)
556*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
557*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
560*4bdc9457SAndroid Build Coastguard Worker }
561*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4,bh_7_bw_92_ies_21_oes_17)562*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_FLOAT_4, bh_7_bw_92_ies_21_oes_17) {
563*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
564*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
565*4bdc9457SAndroid Build Coastguard Worker .output_stride(13)
566*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
567*4bdc9457SAndroid Build Coastguard Worker .block_height(7)
568*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
569*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
570*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
571*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
572*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_float);
573*4bdc9457SAndroid Build Coastguard Worker }
574*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_4)575*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_4) {
576*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
577*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
578*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
579*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
580*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
581*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
582*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
583*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_2_bw_1_8)586*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_2_bw_1_8) {
587*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 2; ++i){
588*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
589*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
590*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
591*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
592*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
593*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
594*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
595*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
597*4bdc9457SAndroid Build Coastguard Worker }
598*4bdc9457SAndroid Build Coastguard Worker }
599*4bdc9457SAndroid Build Coastguard Worker }
600*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_8)601*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_8) {
602*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
603*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
604*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
605*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
606*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
607*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
608*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
609*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
610*4bdc9457SAndroid Build Coastguard Worker }
611*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_5_8)612*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_5_8) {
613*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
614*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
615*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
616*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
617*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
618*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
619*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
620*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
621*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
622*4bdc9457SAndroid Build Coastguard Worker }
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_2_bw_5_8)625*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_2_bw_5_8) {
626*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
628*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
629*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
630*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
631*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
632*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_2_bw_4)638*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_2_bw_4) {
639*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
640*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
641*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
642*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
643*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
644*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
647*4bdc9457SAndroid Build Coastguard Worker }
648*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_2_2_bw_4)649*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_2_2_bw_4){
650*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
651*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
652*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
653*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
654*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
655*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
656*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
659*4bdc9457SAndroid Build Coastguard Worker }
660*4bdc9457SAndroid Build Coastguard Worker }
661*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_2_2_bw_8)662*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_2_2_bw_8){
663*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
664*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
665*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
666*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
667*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
668*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
669*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
672*4bdc9457SAndroid Build Coastguard Worker }
673*4bdc9457SAndroid Build Coastguard Worker }
674*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_2_2_bw_5_8)675*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_2_2_bw_5_8) {
676*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
677*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
678*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
679*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
680*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
681*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
682*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
683*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
684*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
685*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
686*4bdc9457SAndroid Build Coastguard Worker }
687*4bdc9457SAndroid Build Coastguard Worker }
688*4bdc9457SAndroid Build Coastguard Worker }
689*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_4_is_8)690*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_4_is_8) {
691*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
692*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
693*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
694*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
695*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
696*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
699*4bdc9457SAndroid Build Coastguard Worker }
700*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_4_os_2)701*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_4_os_2) {
702*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
703*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
704*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
705*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
706*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
707*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
708*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
709*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
710*4bdc9457SAndroid Build Coastguard Worker }
711*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_1_bw_4_is_8_os_2)712*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_1_bw_4_is_8_os_2) {
713*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
714*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
715*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
716*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
717*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
718*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
719*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
721*4bdc9457SAndroid Build Coastguard Worker }
722*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_17_bw_76_ies_15)723*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_17_bw_76_ies_15) {
724*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
725*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
726*4bdc9457SAndroid Build Coastguard Worker .output_stride(17)
727*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
728*4bdc9457SAndroid Build Coastguard Worker .block_height(17)
729*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
730*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
731*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
732*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
733*4bdc9457SAndroid Build Coastguard Worker }
734*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_3_bw_20_oes_15)735*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_3_bw_20_oes_15) {
736*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
737*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
738*4bdc9457SAndroid Build Coastguard Worker .output_stride(3)
739*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
740*4bdc9457SAndroid Build Coastguard Worker .block_height(3)
741*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
742*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
743*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
745*4bdc9457SAndroid Build Coastguard Worker }
746*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4,bh_7_bw_92_ies_21_oes_17)747*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__1X4_SCALAR_INT_4, bh_7_bw_92_ies_21_oes_17) {
748*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
749*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
750*4bdc9457SAndroid Build Coastguard Worker .output_stride(13)
751*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
752*4bdc9457SAndroid Build Coastguard Worker .block_height(7)
753*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
754*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
755*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
756*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__1x4_scalar_int);
758*4bdc9457SAndroid Build Coastguard Worker }
759*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_1)760*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_1) {
761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
762*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
763*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
764*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
765*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
766*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
769*4bdc9457SAndroid Build Coastguard Worker }
770*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_1_4_bw_1_2)771*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_1_4_bw_1_2) {
772*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
773*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 2; ++j){
774*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
775*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
776*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
777*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
778*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
779*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
782*4bdc9457SAndroid Build Coastguard Worker }
783*4bdc9457SAndroid Build Coastguard Worker }
784*4bdc9457SAndroid Build Coastguard Worker }
785*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_2)786*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_2) {
787*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
788*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
789*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
790*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
791*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
792*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
795*4bdc9457SAndroid Build Coastguard Worker }
796*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_2_2)797*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_2_2) {
798*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
799*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
800*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
801*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
802*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
803*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
804*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
805*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
806*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
807*4bdc9457SAndroid Build Coastguard Worker }
808*4bdc9457SAndroid Build Coastguard Worker }
809*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_4_bw_2_2)810*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_4_bw_2_2) {
811*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
812*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
813*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
814*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
815*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
816*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
817*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
818*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
820*4bdc9457SAndroid Build Coastguard Worker }
821*4bdc9457SAndroid Build Coastguard Worker }
822*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_4_bw_1)823*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_4_bw_1) {
824*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
825*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
826*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
827*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
828*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
829*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
830*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
831*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
832*4bdc9457SAndroid Build Coastguard Worker }
833*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_3_4_bw_1)834*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_3_4_bw_1){
835*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
836*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
837*4bdc9457SAndroid Build Coastguard Worker .input_stride(18)
838*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
839*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
840*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
841*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
842*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
843*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
844*4bdc9457SAndroid Build Coastguard Worker }
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_3_4_bw_2)847*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_3_4_bw_2){
848*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
849*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
850*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
851*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
852*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
853*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
854*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
855*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
856*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
857*4bdc9457SAndroid Build Coastguard Worker }
858*4bdc9457SAndroid Build Coastguard Worker }
859*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_3_4_bw_2_2)860*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_3_4_bw_2_2) {
861*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
862*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 2; j < 2; ++j){
863*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
864*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
865*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
866*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
867*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
868*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
869*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
870*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
871*4bdc9457SAndroid Build Coastguard Worker }
872*4bdc9457SAndroid Build Coastguard Worker }
873*4bdc9457SAndroid Build Coastguard Worker }
874*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_1_is_2)875*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_1_is_2) {
876*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
877*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
878*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
879*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
880*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
881*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
882*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
883*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
884*4bdc9457SAndroid Build Coastguard Worker }
885*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_1_os_4)886*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_1_os_4) {
887*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
888*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
889*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
890*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
891*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
892*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
893*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
894*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_2_bw_1_is_2_os_4)897*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_2_bw_1_is_2_os_4) {
898*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
899*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
900*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
901*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
902*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
903*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
904*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
905*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
906*4bdc9457SAndroid Build Coastguard Worker }
907*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_34_bw_19_ies_15)908*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_34_bw_19_ies_15) {
909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
910*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
911*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
912*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
913*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
914*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
915*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
916*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
917*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
918*4bdc9457SAndroid Build Coastguard Worker }
919*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_6_bw_5_oes_15)920*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_6_bw_5_oes_15) {
921*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
922*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
923*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
924*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
925*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
926*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
927*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
930*4bdc9457SAndroid Build Coastguard Worker }
931*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4,bh_14_bw_23_ies_21_oes_17)932*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_FLOAT_4, bh_14_bw_23_ies_21_oes_17) {
933*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
934*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
935*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
936*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
937*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
938*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
939*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
940*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
941*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
942*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_float);
943*4bdc9457SAndroid Build Coastguard Worker }
944*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_1)945*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_1) {
946*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
947*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
948*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
949*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
950*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
951*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
952*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
953*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
954*4bdc9457SAndroid Build Coastguard Worker }
955*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_1_4_bw_1_2)956*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_1_4_bw_1_2) {
957*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
958*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 2; ++j){
959*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
960*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
961*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
962*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
963*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
964*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
965*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
967*4bdc9457SAndroid Build Coastguard Worker }
968*4bdc9457SAndroid Build Coastguard Worker }
969*4bdc9457SAndroid Build Coastguard Worker }
970*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_2)971*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_2) {
972*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
973*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
974*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
975*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
976*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
977*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
978*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
979*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
980*4bdc9457SAndroid Build Coastguard Worker }
981*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_2_2)982*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_2_2) {
983*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
984*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
985*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
986*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
987*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
988*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
989*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
990*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
991*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
992*4bdc9457SAndroid Build Coastguard Worker }
993*4bdc9457SAndroid Build Coastguard Worker }
994*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_4_bw_2_2)995*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_4_bw_2_2) {
996*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
997*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
998*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
999*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1000*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1001*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1002*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1003*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1005*4bdc9457SAndroid Build Coastguard Worker }
1006*4bdc9457SAndroid Build Coastguard Worker }
1007*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_4_bw_1)1008*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_4_bw_1) {
1009*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1010*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1011*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1012*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1013*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1014*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1015*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1016*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1017*4bdc9457SAndroid Build Coastguard Worker }
1018*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_3_4_bw_1)1019*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_3_4_bw_1){
1020*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1021*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1022*4bdc9457SAndroid Build Coastguard Worker .input_stride(18)
1023*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1024*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1025*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1026*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1027*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1029*4bdc9457SAndroid Build Coastguard Worker }
1030*4bdc9457SAndroid Build Coastguard Worker }
1031*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_3_4_bw_2)1032*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_3_4_bw_2){
1033*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1034*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1035*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1036*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1037*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1038*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1039*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1040*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1042*4bdc9457SAndroid Build Coastguard Worker }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_3_4_bw_2_2)1045*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_3_4_bw_2_2) {
1046*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1047*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 2; j < 2; ++j){
1048*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1049*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1050*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1051*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1052*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1053*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1054*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1055*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1056*4bdc9457SAndroid Build Coastguard Worker }
1057*4bdc9457SAndroid Build Coastguard Worker }
1058*4bdc9457SAndroid Build Coastguard Worker }
1059*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_1_is_2)1060*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_1_is_2) {
1061*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1062*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1063*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1064*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1065*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1066*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1067*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1068*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_1_os_4)1071*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_1_os_4) {
1072*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1073*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1074*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1075*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1076*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1077*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1078*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1079*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1080*4bdc9457SAndroid Build Coastguard Worker }
1081*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_2_bw_1_is_2_os_4)1082*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_2_bw_1_is_2_os_4) {
1083*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1084*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1085*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1086*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1087*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1088*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1091*4bdc9457SAndroid Build Coastguard Worker }
1092*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_34_bw_19_ies_15)1093*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_34_bw_19_ies_15) {
1094*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1095*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
1096*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1097*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
1098*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1099*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1100*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
1101*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1102*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1103*4bdc9457SAndroid Build Coastguard Worker }
1104*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_6_bw_5_oes_15)1105*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_6_bw_5_oes_15) {
1106*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1107*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
1108*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1109*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
1110*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1111*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1112*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1113*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1115*4bdc9457SAndroid Build Coastguard Worker }
1116*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4,bh_14_bw_23_ies_21_oes_17)1117*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X1_SCALAR_INT_4, bh_14_bw_23_ies_21_oes_17) {
1118*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1119*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
1120*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1121*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
1122*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1123*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1124*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
1125*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
1126*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1127*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x1_scalar_int);
1128*4bdc9457SAndroid Build Coastguard Worker }
1129*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_2)1130*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_2) {
1131*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1132*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1133*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1134*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1135*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1136*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1139*4bdc9457SAndroid Build Coastguard Worker }
1140*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_1_4_bw_1_4)1141*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_1_4_bw_1_4) {
1142*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
1143*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
1144*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1145*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1146*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1147*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1148*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1149*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1150*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1152*4bdc9457SAndroid Build Coastguard Worker }
1153*4bdc9457SAndroid Build Coastguard Worker }
1154*4bdc9457SAndroid Build Coastguard Worker }
1155*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_4)1156*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_4) {
1157*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1158*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1159*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1160*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1161*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1162*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1163*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1165*4bdc9457SAndroid Build Coastguard Worker }
1166*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_3_4)1167*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_3_4) {
1168*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1169*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1170*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1171*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1172*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1173*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1174*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1175*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1176*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1177*4bdc9457SAndroid Build Coastguard Worker }
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_4_bw_3_4)1180*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_4_bw_3_4) {
1181*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1182*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1183*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1184*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1185*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1186*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1187*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1190*4bdc9457SAndroid Build Coastguard Worker }
1191*4bdc9457SAndroid Build Coastguard Worker }
1192*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_4_bw_2)1193*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_4_bw_2) {
1194*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1195*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1196*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1197*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1198*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1199*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1200*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1201*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1202*4bdc9457SAndroid Build Coastguard Worker }
1203*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_3_4_bw_2)1204*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_3_4_bw_2){
1205*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1206*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1207*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
1208*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1209*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
1210*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1211*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1214*4bdc9457SAndroid Build Coastguard Worker }
1215*4bdc9457SAndroid Build Coastguard Worker }
1216*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_3_4_bw_4)1217*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_3_4_bw_4){
1218*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1219*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1220*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1221*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1222*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1223*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1224*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker }
1229*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_3_4_bw_3_4)1230*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_3_4_bw_3_4) {
1231*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1232*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
1233*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1234*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1235*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1236*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1237*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1238*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1241*4bdc9457SAndroid Build Coastguard Worker }
1242*4bdc9457SAndroid Build Coastguard Worker }
1243*4bdc9457SAndroid Build Coastguard Worker }
1244*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_2_is_4)1245*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_2_is_4) {
1246*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1247*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1248*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1249*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1250*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1251*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1252*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_2_os_4)1256*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_2_os_4) {
1257*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1258*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1259*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1260*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1261*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1262*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_2_bw_2_is_4_os_4)1267*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_2_bw_2_is_4_os_4) {
1268*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1269*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1270*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1271*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1272*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1273*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1274*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1275*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1276*4bdc9457SAndroid Build Coastguard Worker }
1277*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_34_bw_38_ies_15)1278*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_34_bw_38_ies_15) {
1279*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1280*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
1281*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1282*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
1283*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1284*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1285*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
1286*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1287*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1288*4bdc9457SAndroid Build Coastguard Worker }
1289*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_6_bw_10_oes_15)1290*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_6_bw_10_oes_15) {
1291*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1292*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
1293*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1294*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
1295*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1296*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1297*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1298*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1300*4bdc9457SAndroid Build Coastguard Worker }
1301*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4,bh_14_bw_46_ies_21_oes_17)1302*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_FLOAT_4, bh_14_bw_46_ies_21_oes_17) {
1303*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1304*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
1305*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1306*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
1307*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1308*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1309*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
1310*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
1311*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1312*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_float);
1313*4bdc9457SAndroid Build Coastguard Worker }
1314*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_2)1315*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_2) {
1316*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1317*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1318*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1319*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1320*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1321*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1322*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1324*4bdc9457SAndroid Build Coastguard Worker }
1325*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_1_4_bw_1_4)1326*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_1_4_bw_1_4) {
1327*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
1328*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
1329*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1330*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1331*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1332*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1333*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1334*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1337*4bdc9457SAndroid Build Coastguard Worker }
1338*4bdc9457SAndroid Build Coastguard Worker }
1339*4bdc9457SAndroid Build Coastguard Worker }
1340*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_4)1341*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_4) {
1342*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1343*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1344*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1345*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1346*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1347*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1348*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1349*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1350*4bdc9457SAndroid Build Coastguard Worker }
1351*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_3_4)1352*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_3_4) {
1353*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1354*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1355*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1356*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1357*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1358*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1359*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1360*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1361*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1362*4bdc9457SAndroid Build Coastguard Worker }
1363*4bdc9457SAndroid Build Coastguard Worker }
1364*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_4_bw_3_4)1365*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_4_bw_3_4) {
1366*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1367*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1368*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1369*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1370*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1371*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1372*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1375*4bdc9457SAndroid Build Coastguard Worker }
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_4_bw_2)1378*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_4_bw_2) {
1379*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1380*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1381*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1382*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1383*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1384*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1385*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1386*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1387*4bdc9457SAndroid Build Coastguard Worker }
1388*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_3_4_bw_2)1389*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_3_4_bw_2){
1390*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1391*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1392*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
1393*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1394*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
1395*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1396*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1399*4bdc9457SAndroid Build Coastguard Worker }
1400*4bdc9457SAndroid Build Coastguard Worker }
1401*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_3_4_bw_4)1402*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_3_4_bw_4){
1403*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1404*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1405*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1406*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1407*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1408*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1409*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_3_4_bw_3_4)1415*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_3_4_bw_3_4) {
1416*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1417*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
1418*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1419*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1420*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1421*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1422*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1423*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1424*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1425*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1426*4bdc9457SAndroid Build Coastguard Worker }
1427*4bdc9457SAndroid Build Coastguard Worker }
1428*4bdc9457SAndroid Build Coastguard Worker }
1429*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_2_is_4)1430*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_2_is_4) {
1431*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1432*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1433*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1434*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1435*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1436*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1437*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1438*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1439*4bdc9457SAndroid Build Coastguard Worker }
1440*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_2_os_4)1441*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_2_os_4) {
1442*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1443*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1444*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1445*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1446*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1447*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_2_bw_2_is_4_os_4)1452*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_2_bw_2_is_4_os_4) {
1453*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1454*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1455*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1456*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1457*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1458*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1459*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1460*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1461*4bdc9457SAndroid Build Coastguard Worker }
1462*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_34_bw_38_ies_15)1463*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_34_bw_38_ies_15) {
1464*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1465*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
1466*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1467*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
1468*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1469*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1470*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
1471*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1472*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1473*4bdc9457SAndroid Build Coastguard Worker }
1474*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_6_bw_10_oes_15)1475*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_6_bw_10_oes_15) {
1476*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1477*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
1478*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1479*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
1480*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1481*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1482*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1483*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1484*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1485*4bdc9457SAndroid Build Coastguard Worker }
1486*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4,bh_14_bw_46_ies_21_oes_17)1487*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_SCALAR_INT_4, bh_14_bw_46_ies_21_oes_17) {
1488*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1489*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
1490*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1491*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
1492*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1493*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1494*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
1495*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
1496*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1497*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_scalar_int);
1498*4bdc9457SAndroid Build Coastguard Worker }
1499*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_4)1500*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_4) {
1501*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1502*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1503*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1504*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1505*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1506*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1507*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1508*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1509*4bdc9457SAndroid Build Coastguard Worker }
1510*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_1_4_bw_1_8)1511*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_1_4_bw_1_8) {
1512*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
1513*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
1514*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1515*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1516*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1517*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1518*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1519*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1520*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1521*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1522*4bdc9457SAndroid Build Coastguard Worker }
1523*4bdc9457SAndroid Build Coastguard Worker }
1524*4bdc9457SAndroid Build Coastguard Worker }
1525*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_8)1526*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_8) {
1527*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1528*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1529*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1530*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1531*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1532*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1533*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1534*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1535*4bdc9457SAndroid Build Coastguard Worker }
1536*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_5_8)1537*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_5_8) {
1538*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1539*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1540*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1541*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1542*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1543*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1544*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1545*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1546*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1547*4bdc9457SAndroid Build Coastguard Worker }
1548*4bdc9457SAndroid Build Coastguard Worker }
1549*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_4_bw_5_8)1550*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_4_bw_5_8) {
1551*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1552*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1553*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1554*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1555*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1556*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1557*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1560*4bdc9457SAndroid Build Coastguard Worker }
1561*4bdc9457SAndroid Build Coastguard Worker }
1562*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_4_bw_4)1563*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_4_bw_4) {
1564*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1565*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1566*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1567*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1568*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1569*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1570*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1571*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1572*4bdc9457SAndroid Build Coastguard Worker }
1573*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_3_4_bw_4)1574*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_3_4_bw_4){
1575*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1576*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1577*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
1578*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1579*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
1580*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1581*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1582*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1583*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1584*4bdc9457SAndroid Build Coastguard Worker }
1585*4bdc9457SAndroid Build Coastguard Worker }
1586*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_3_4_bw_8)1587*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_3_4_bw_8){
1588*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1589*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1590*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1591*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1592*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1593*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1594*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1595*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1597*4bdc9457SAndroid Build Coastguard Worker }
1598*4bdc9457SAndroid Build Coastguard Worker }
1599*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_3_4_bw_5_8)1600*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_3_4_bw_5_8) {
1601*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1602*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
1603*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1604*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1605*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1606*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1607*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1608*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1609*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1610*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1611*4bdc9457SAndroid Build Coastguard Worker }
1612*4bdc9457SAndroid Build Coastguard Worker }
1613*4bdc9457SAndroid Build Coastguard Worker }
1614*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_4_is_8)1615*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_4_is_8) {
1616*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1617*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1618*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1619*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1620*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1621*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1622*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1623*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1624*4bdc9457SAndroid Build Coastguard Worker }
1625*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_4_os_4)1626*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_4_os_4) {
1627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1628*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1629*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1630*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1631*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1632*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1635*4bdc9457SAndroid Build Coastguard Worker }
1636*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_2_bw_4_is_8_os_4)1637*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_2_bw_4_is_8_os_4) {
1638*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1639*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1640*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1641*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1642*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1643*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1644*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1645*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1646*4bdc9457SAndroid Build Coastguard Worker }
1647*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_34_bw_76_ies_15)1648*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_34_bw_76_ies_15) {
1649*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1650*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
1651*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1652*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
1653*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1654*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1655*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
1656*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1657*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1658*4bdc9457SAndroid Build Coastguard Worker }
1659*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_6_bw_20_oes_15)1660*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_6_bw_20_oes_15) {
1661*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1662*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
1663*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1664*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
1665*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1666*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1667*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1668*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1669*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1670*4bdc9457SAndroid Build Coastguard Worker }
1671*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4,bh_14_bw_92_ies_21_oes_17)1672*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_FLOAT_4, bh_14_bw_92_ies_21_oes_17) {
1673*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1674*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
1675*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1676*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
1677*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1678*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1679*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
1680*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
1681*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1682*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_float);
1683*4bdc9457SAndroid Build Coastguard Worker }
1684*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_4)1685*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_4) {
1686*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1687*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1688*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1689*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1690*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1691*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1692*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1693*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1694*4bdc9457SAndroid Build Coastguard Worker }
1695*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_1_4_bw_1_8)1696*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_1_4_bw_1_8) {
1697*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
1698*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
1699*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1700*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1701*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1702*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1703*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1704*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1705*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1706*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1707*4bdc9457SAndroid Build Coastguard Worker }
1708*4bdc9457SAndroid Build Coastguard Worker }
1709*4bdc9457SAndroid Build Coastguard Worker }
1710*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_8)1711*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_8) {
1712*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1713*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1714*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1715*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1716*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1717*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1718*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1719*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1720*4bdc9457SAndroid Build Coastguard Worker }
1721*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_5_8)1722*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_5_8) {
1723*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1724*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1725*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1726*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1727*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1728*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1729*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1730*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1731*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1732*4bdc9457SAndroid Build Coastguard Worker }
1733*4bdc9457SAndroid Build Coastguard Worker }
1734*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_4_bw_5_8)1735*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_4_bw_5_8) {
1736*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1737*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1738*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1739*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1740*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1741*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1742*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1743*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1745*4bdc9457SAndroid Build Coastguard Worker }
1746*4bdc9457SAndroid Build Coastguard Worker }
1747*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_4_bw_4)1748*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_4_bw_4) {
1749*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1750*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1751*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1752*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1753*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1754*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1755*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1756*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1757*4bdc9457SAndroid Build Coastguard Worker }
1758*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_3_4_bw_4)1759*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_3_4_bw_4){
1760*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1762*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
1763*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1764*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
1765*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1766*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1769*4bdc9457SAndroid Build Coastguard Worker }
1770*4bdc9457SAndroid Build Coastguard Worker }
1771*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_3_4_bw_8)1772*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_3_4_bw_8){
1773*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1774*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1775*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1776*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1777*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1778*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1779*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1782*4bdc9457SAndroid Build Coastguard Worker }
1783*4bdc9457SAndroid Build Coastguard Worker }
1784*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_3_4_bw_5_8)1785*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_3_4_bw_5_8) {
1786*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1787*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
1788*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1789*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1790*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1791*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1792*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1793*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1794*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1795*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1796*4bdc9457SAndroid Build Coastguard Worker }
1797*4bdc9457SAndroid Build Coastguard Worker }
1798*4bdc9457SAndroid Build Coastguard Worker }
1799*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_4_is_8)1800*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_4_is_8) {
1801*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1802*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1803*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1804*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1805*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1806*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1807*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1809*4bdc9457SAndroid Build Coastguard Worker }
1810*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_4_os_4)1811*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_4_os_4) {
1812*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1813*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1814*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1815*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1816*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1817*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1818*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1820*4bdc9457SAndroid Build Coastguard Worker }
1821*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_2_bw_4_is_8_os_4)1822*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_2_bw_4_is_8_os_4) {
1823*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1824*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1825*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1826*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1827*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1828*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1829*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1830*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1831*4bdc9457SAndroid Build Coastguard Worker }
1832*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_34_bw_76_ies_15)1833*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_34_bw_76_ies_15) {
1834*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1835*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
1836*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1837*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
1838*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1839*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1840*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
1841*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1842*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1843*4bdc9457SAndroid Build Coastguard Worker }
1844*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_6_bw_20_oes_15)1845*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_6_bw_20_oes_15) {
1846*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1847*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
1848*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1849*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
1850*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1851*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1852*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1853*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1855*4bdc9457SAndroid Build Coastguard Worker }
1856*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4,bh_14_bw_92_ies_21_oes_17)1857*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X4_SCALAR_INT_4, bh_14_bw_92_ies_21_oes_17) {
1858*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1859*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
1860*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1861*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
1862*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1863*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1864*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
1865*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
1866*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1867*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x4_scalar_int);
1868*4bdc9457SAndroid Build Coastguard Worker }
1869*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_1)1870*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_1) {
1871*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1872*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1873*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1874*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1875*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1876*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1877*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1878*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1879*4bdc9457SAndroid Build Coastguard Worker }
1880*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_1_8_bw_1_2)1881*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_1_8_bw_1_2) {
1882*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
1883*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 2; ++j){
1884*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1885*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1886*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1887*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1888*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1889*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1890*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1891*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1892*4bdc9457SAndroid Build Coastguard Worker }
1893*4bdc9457SAndroid Build Coastguard Worker }
1894*4bdc9457SAndroid Build Coastguard Worker }
1895*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_2)1896*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_2) {
1897*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1898*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1899*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1900*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1901*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1902*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1903*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1904*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1905*4bdc9457SAndroid Build Coastguard Worker }
1906*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_2_2)1907*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_2_2) {
1908*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
1909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1910*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1911*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1912*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1913*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1914*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1917*4bdc9457SAndroid Build Coastguard Worker }
1918*4bdc9457SAndroid Build Coastguard Worker }
1919*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_8_bw_2_2)1920*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_8_bw_2_2) {
1921*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
1922*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1923*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1924*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1925*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1926*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1927*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1930*4bdc9457SAndroid Build Coastguard Worker }
1931*4bdc9457SAndroid Build Coastguard Worker }
1932*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_8_bw_1)1933*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_8_bw_1) {
1934*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1935*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1936*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1937*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1938*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1939*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1940*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1941*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1942*4bdc9457SAndroid Build Coastguard Worker }
1943*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_5_8_bw_1)1944*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_5_8_bw_1){
1945*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1946*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1947*4bdc9457SAndroid Build Coastguard Worker .input_stride(18)
1948*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1949*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1950*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1951*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1952*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1953*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1954*4bdc9457SAndroid Build Coastguard Worker }
1955*4bdc9457SAndroid Build Coastguard Worker }
1956*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_5_8_bw_2)1957*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_5_8_bw_2){
1958*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1959*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1960*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1961*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1962*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1963*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1964*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1965*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1967*4bdc9457SAndroid Build Coastguard Worker }
1968*4bdc9457SAndroid Build Coastguard Worker }
1969*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_5_8_bw_2_2)1970*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_5_8_bw_2_2) {
1971*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1972*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 2; j < 2; ++j){
1973*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1974*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1975*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1976*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1977*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1978*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1979*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1980*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1981*4bdc9457SAndroid Build Coastguard Worker }
1982*4bdc9457SAndroid Build Coastguard Worker }
1983*4bdc9457SAndroid Build Coastguard Worker }
1984*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_1_is_2)1985*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_1_is_2) {
1986*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1987*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1988*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1989*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1990*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1991*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
1992*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1993*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
1994*4bdc9457SAndroid Build Coastguard Worker }
1995*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_1_os_8)1996*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_1_os_8) {
1997*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1998*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1999*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2000*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2001*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2002*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2003*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
2005*4bdc9457SAndroid Build Coastguard Worker }
2006*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_4_bw_1_is_2_os_8)2007*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_4_bw_1_is_2_os_8) {
2008*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2009*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2010*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2011*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2012*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2013*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2014*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2015*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
2016*4bdc9457SAndroid Build Coastguard Worker }
2017*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_68_bw_19_ies_15)2018*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_68_bw_19_ies_15) {
2019*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2020*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
2021*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2022*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
2023*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2024*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2025*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2026*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2027*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
2028*4bdc9457SAndroid Build Coastguard Worker }
2029*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_12_bw_5_oes_15)2030*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_12_bw_5_oes_15) {
2031*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2032*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
2033*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2034*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
2035*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2036*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2037*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2038*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2039*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
2040*4bdc9457SAndroid Build Coastguard Worker }
2041*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4,bh_28_bw_23_ies_21_oes_17)2042*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_FLOAT_4, bh_28_bw_23_ies_21_oes_17) {
2043*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2044*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
2045*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2046*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
2047*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2048*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2049*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2050*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_float);
2053*4bdc9457SAndroid Build Coastguard Worker }
2054*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_1)2055*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_1) {
2056*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2057*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2058*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2059*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2060*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2061*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2062*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2063*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2064*4bdc9457SAndroid Build Coastguard Worker }
2065*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_1_8_bw_1_2)2066*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_1_8_bw_1_2) {
2067*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2068*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 2; ++j){
2069*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2070*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2071*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2072*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2073*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2074*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2075*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2076*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2077*4bdc9457SAndroid Build Coastguard Worker }
2078*4bdc9457SAndroid Build Coastguard Worker }
2079*4bdc9457SAndroid Build Coastguard Worker }
2080*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_2)2081*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_2) {
2082*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2083*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2084*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2085*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2086*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2087*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2088*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2089*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2090*4bdc9457SAndroid Build Coastguard Worker }
2091*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_2_2)2092*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_2_2) {
2093*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
2094*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2095*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2096*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2097*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2098*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2099*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2100*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2101*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2102*4bdc9457SAndroid Build Coastguard Worker }
2103*4bdc9457SAndroid Build Coastguard Worker }
2104*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_8_bw_2_2)2105*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_8_bw_2_2) {
2106*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
2107*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2108*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2109*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2110*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2111*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2112*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2113*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2115*4bdc9457SAndroid Build Coastguard Worker }
2116*4bdc9457SAndroid Build Coastguard Worker }
2117*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_8_bw_1)2118*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_8_bw_1) {
2119*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2120*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
2121*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2122*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2123*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2124*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2125*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2126*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2127*4bdc9457SAndroid Build Coastguard Worker }
2128*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_5_8_bw_1)2129*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_5_8_bw_1){
2130*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2131*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2132*4bdc9457SAndroid Build Coastguard Worker .input_stride(18)
2133*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2134*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2135*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2136*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2139*4bdc9457SAndroid Build Coastguard Worker }
2140*4bdc9457SAndroid Build Coastguard Worker }
2141*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_5_8_bw_2)2142*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_5_8_bw_2){
2143*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2144*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2145*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2146*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2147*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2148*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2149*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2150*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2152*4bdc9457SAndroid Build Coastguard Worker }
2153*4bdc9457SAndroid Build Coastguard Worker }
2154*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_5_8_bw_2_2)2155*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_5_8_bw_2_2) {
2156*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2157*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 2; j < 2; ++j){
2158*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2159*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2160*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2161*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2162*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2163*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2164*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2166*4bdc9457SAndroid Build Coastguard Worker }
2167*4bdc9457SAndroid Build Coastguard Worker }
2168*4bdc9457SAndroid Build Coastguard Worker }
2169*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_1_is_2)2170*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_1_is_2) {
2171*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2172*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2173*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2174*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2175*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2176*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2177*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2179*4bdc9457SAndroid Build Coastguard Worker }
2180*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_1_os_8)2181*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_1_os_8) {
2182*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2183*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
2184*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2185*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2186*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2187*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2190*4bdc9457SAndroid Build Coastguard Worker }
2191*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_4_bw_1_is_2_os_8)2192*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_4_bw_1_is_2_os_8) {
2193*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2194*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2195*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2196*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
2197*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2198*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2199*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2200*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2201*4bdc9457SAndroid Build Coastguard Worker }
2202*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_68_bw_19_ies_15)2203*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_68_bw_19_ies_15) {
2204*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2205*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
2206*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2207*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
2208*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2209*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2210*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2211*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2212*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2213*4bdc9457SAndroid Build Coastguard Worker }
2214*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_12_bw_5_oes_15)2215*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_12_bw_5_oes_15) {
2216*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2217*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
2218*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2219*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
2220*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2221*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2222*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2223*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2224*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2225*4bdc9457SAndroid Build Coastguard Worker }
2226*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4,bh_28_bw_23_ies_21_oes_17)2227*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X1_SCALAR_INT_4, bh_28_bw_23_ies_21_oes_17) {
2228*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2229*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
2230*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2231*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
2232*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2233*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2234*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2235*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2236*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2237*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x1_scalar_int);
2238*4bdc9457SAndroid Build Coastguard Worker }
2239*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_2)2240*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_2) {
2241*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2242*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2243*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2244*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2245*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2246*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2247*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2248*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2249*4bdc9457SAndroid Build Coastguard Worker }
2250*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_1_8_bw_1_4)2251*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_1_8_bw_1_4) {
2252*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2253*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
2254*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2255*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2256*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2257*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2258*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2259*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2260*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2261*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2262*4bdc9457SAndroid Build Coastguard Worker }
2263*4bdc9457SAndroid Build Coastguard Worker }
2264*4bdc9457SAndroid Build Coastguard Worker }
2265*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_4)2266*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_4) {
2267*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2268*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2269*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2270*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2271*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2272*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2273*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2274*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2275*4bdc9457SAndroid Build Coastguard Worker }
2276*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_3_4)2277*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_3_4) {
2278*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
2279*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2280*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2281*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2282*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2283*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2284*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2285*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2286*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2287*4bdc9457SAndroid Build Coastguard Worker }
2288*4bdc9457SAndroid Build Coastguard Worker }
2289*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_8_bw_3_4)2290*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_8_bw_3_4) {
2291*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
2292*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2293*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2294*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2295*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2296*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2297*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2298*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2300*4bdc9457SAndroid Build Coastguard Worker }
2301*4bdc9457SAndroid Build Coastguard Worker }
2302*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_8_bw_2)2303*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_8_bw_2) {
2304*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2305*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2306*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2307*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2308*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2309*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2310*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2311*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2312*4bdc9457SAndroid Build Coastguard Worker }
2313*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_5_8_bw_2)2314*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_5_8_bw_2){
2315*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2316*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2317*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
2318*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2319*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
2320*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2321*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2322*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2324*4bdc9457SAndroid Build Coastguard Worker }
2325*4bdc9457SAndroid Build Coastguard Worker }
2326*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_5_8_bw_4)2327*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_5_8_bw_4){
2328*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2329*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2330*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2331*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2332*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2333*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2334*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2337*4bdc9457SAndroid Build Coastguard Worker }
2338*4bdc9457SAndroid Build Coastguard Worker }
2339*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_5_8_bw_3_4)2340*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_5_8_bw_3_4) {
2341*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2342*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
2343*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2344*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2345*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2346*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2347*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2348*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2351*4bdc9457SAndroid Build Coastguard Worker }
2352*4bdc9457SAndroid Build Coastguard Worker }
2353*4bdc9457SAndroid Build Coastguard Worker }
2354*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_2_is_4)2355*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_2_is_4) {
2356*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2357*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2358*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2359*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2360*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2361*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2362*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2363*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2364*4bdc9457SAndroid Build Coastguard Worker }
2365*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_2_os_8)2366*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_2_os_8) {
2367*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2368*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2369*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2370*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2371*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2372*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2375*4bdc9457SAndroid Build Coastguard Worker }
2376*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_4_bw_2_is_4_os_8)2377*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_4_bw_2_is_4_os_8) {
2378*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2379*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2380*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2381*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2382*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2383*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2384*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2385*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2386*4bdc9457SAndroid Build Coastguard Worker }
2387*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_68_bw_38_ies_15)2388*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_68_bw_38_ies_15) {
2389*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2390*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
2391*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2392*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
2393*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2394*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2395*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2396*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2397*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2398*4bdc9457SAndroid Build Coastguard Worker }
2399*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_12_bw_10_oes_15)2400*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_12_bw_10_oes_15) {
2401*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2402*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
2403*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2404*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
2405*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2406*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2407*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2408*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2409*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2410*4bdc9457SAndroid Build Coastguard Worker }
2411*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4,bh_28_bw_46_ies_21_oes_17)2412*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_FLOAT_4, bh_28_bw_46_ies_21_oes_17) {
2413*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2414*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
2415*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2416*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
2417*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2418*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2419*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2420*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2421*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2422*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_float);
2423*4bdc9457SAndroid Build Coastguard Worker }
2424*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_2)2425*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_2) {
2426*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2427*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2428*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2429*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2430*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2431*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2432*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2433*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2434*4bdc9457SAndroid Build Coastguard Worker }
2435*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_1_8_bw_1_4)2436*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_1_8_bw_1_4) {
2437*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2438*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
2439*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2440*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2441*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2442*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2443*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2444*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2445*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2446*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2447*4bdc9457SAndroid Build Coastguard Worker }
2448*4bdc9457SAndroid Build Coastguard Worker }
2449*4bdc9457SAndroid Build Coastguard Worker }
2450*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_4)2451*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_4) {
2452*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2453*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2454*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2455*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2456*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2457*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2458*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2459*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2460*4bdc9457SAndroid Build Coastguard Worker }
2461*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_3_4)2462*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_3_4) {
2463*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
2464*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2465*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2466*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2467*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2468*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2469*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2470*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2471*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2472*4bdc9457SAndroid Build Coastguard Worker }
2473*4bdc9457SAndroid Build Coastguard Worker }
2474*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_8_bw_3_4)2475*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_8_bw_3_4) {
2476*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
2477*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2478*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2479*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2480*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2481*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2482*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2483*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2484*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2485*4bdc9457SAndroid Build Coastguard Worker }
2486*4bdc9457SAndroid Build Coastguard Worker }
2487*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_8_bw_2)2488*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_8_bw_2) {
2489*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2490*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2491*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2492*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2493*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2494*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2495*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2496*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2497*4bdc9457SAndroid Build Coastguard Worker }
2498*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_5_8_bw_2)2499*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_5_8_bw_2){
2500*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2501*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2502*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
2503*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2504*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
2505*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2506*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2507*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2508*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2509*4bdc9457SAndroid Build Coastguard Worker }
2510*4bdc9457SAndroid Build Coastguard Worker }
2511*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_5_8_bw_4)2512*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_5_8_bw_4){
2513*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2514*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2515*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2516*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2517*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2518*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2519*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2520*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2521*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2522*4bdc9457SAndroid Build Coastguard Worker }
2523*4bdc9457SAndroid Build Coastguard Worker }
2524*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_5_8_bw_3_4)2525*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_5_8_bw_3_4) {
2526*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2527*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
2528*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2529*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2530*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2531*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2532*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2533*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2536*4bdc9457SAndroid Build Coastguard Worker }
2537*4bdc9457SAndroid Build Coastguard Worker }
2538*4bdc9457SAndroid Build Coastguard Worker }
2539*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_2_is_4)2540*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_2_is_4) {
2541*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2542*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2543*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2544*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2545*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2546*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2547*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2548*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2549*4bdc9457SAndroid Build Coastguard Worker }
2550*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_2_os_8)2551*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_2_os_8) {
2552*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2553*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
2554*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2555*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2556*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2557*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2560*4bdc9457SAndroid Build Coastguard Worker }
2561*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_4_bw_2_is_4_os_8)2562*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_4_bw_2_is_4_os_8) {
2563*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2564*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2565*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2566*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
2567*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2568*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2569*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2570*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2571*4bdc9457SAndroid Build Coastguard Worker }
2572*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_68_bw_38_ies_15)2573*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_68_bw_38_ies_15) {
2574*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2575*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
2576*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2577*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
2578*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2579*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2580*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2581*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2582*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2583*4bdc9457SAndroid Build Coastguard Worker }
2584*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_12_bw_10_oes_15)2585*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_12_bw_10_oes_15) {
2586*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2587*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
2588*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2589*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
2590*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2591*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2592*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2593*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2594*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2595*4bdc9457SAndroid Build Coastguard Worker }
2596*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4,bh_28_bw_46_ies_21_oes_17)2597*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X2_SCALAR_INT_4, bh_28_bw_46_ies_21_oes_17) {
2598*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2599*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
2600*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2601*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
2602*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2603*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2604*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2605*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2606*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2607*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x2_scalar_int);
2608*4bdc9457SAndroid Build Coastguard Worker }
2609*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_4)2610*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_4) {
2611*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2612*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2613*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2614*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2615*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2616*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2617*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2618*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2619*4bdc9457SAndroid Build Coastguard Worker }
2620*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_1_8_bw_1_8)2621*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_1_8_bw_1_8) {
2622*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2623*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
2624*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2625*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2626*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2627*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2628*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2629*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2630*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2631*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2632*4bdc9457SAndroid Build Coastguard Worker }
2633*4bdc9457SAndroid Build Coastguard Worker }
2634*4bdc9457SAndroid Build Coastguard Worker }
2635*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_8)2636*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_8) {
2637*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2638*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2639*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2640*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2641*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2642*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2643*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2644*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2645*4bdc9457SAndroid Build Coastguard Worker }
2646*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_5_8)2647*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_5_8) {
2648*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2649*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2650*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2651*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2652*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2653*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2654*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2655*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2656*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2657*4bdc9457SAndroid Build Coastguard Worker }
2658*4bdc9457SAndroid Build Coastguard Worker }
2659*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_8_bw_5_8)2660*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_8_bw_5_8) {
2661*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2662*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2663*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2664*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2665*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2666*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2667*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2668*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2669*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2670*4bdc9457SAndroid Build Coastguard Worker }
2671*4bdc9457SAndroid Build Coastguard Worker }
2672*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_8_bw_4)2673*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_8_bw_4) {
2674*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2675*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2676*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2677*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2678*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2679*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2680*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2681*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2682*4bdc9457SAndroid Build Coastguard Worker }
2683*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_5_8_bw_4)2684*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_5_8_bw_4){
2685*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2686*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2687*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
2688*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2689*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
2690*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2691*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2692*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2693*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2694*4bdc9457SAndroid Build Coastguard Worker }
2695*4bdc9457SAndroid Build Coastguard Worker }
2696*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_5_8_bw_8)2697*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_5_8_bw_8){
2698*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2699*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2700*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2701*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2702*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2703*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2704*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2705*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2706*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2707*4bdc9457SAndroid Build Coastguard Worker }
2708*4bdc9457SAndroid Build Coastguard Worker }
2709*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_5_8_bw_5_8)2710*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_5_8_bw_5_8) {
2711*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2712*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
2713*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2714*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2715*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2716*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2717*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2718*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2719*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2721*4bdc9457SAndroid Build Coastguard Worker }
2722*4bdc9457SAndroid Build Coastguard Worker }
2723*4bdc9457SAndroid Build Coastguard Worker }
2724*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_4_is_8)2725*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_4_is_8) {
2726*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2727*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2728*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2729*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2730*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2731*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2732*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2733*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2734*4bdc9457SAndroid Build Coastguard Worker }
2735*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_4_os_8)2736*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_4_os_8) {
2737*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2738*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2739*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2740*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2741*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2742*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2743*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2745*4bdc9457SAndroid Build Coastguard Worker }
2746*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_4_bw_4_is_8_os_8)2747*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_4_bw_4_is_8_os_8) {
2748*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2749*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2750*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2751*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2752*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2753*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2754*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2755*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2756*4bdc9457SAndroid Build Coastguard Worker }
2757*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_68_bw_76_ies_15)2758*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_68_bw_76_ies_15) {
2759*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2760*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
2761*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2762*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
2763*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2764*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2765*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2766*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2767*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2768*4bdc9457SAndroid Build Coastguard Worker }
2769*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_12_bw_20_oes_15)2770*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_12_bw_20_oes_15) {
2771*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2772*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
2773*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2774*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
2775*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2776*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2777*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2778*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2779*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2780*4bdc9457SAndroid Build Coastguard Worker }
2781*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4,bh_28_bw_92_ies_21_oes_17)2782*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_FLOAT_4, bh_28_bw_92_ies_21_oes_17) {
2783*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2784*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
2785*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2786*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
2787*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2788*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2789*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2790*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2791*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2792*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_float);
2793*4bdc9457SAndroid Build Coastguard Worker }
2794*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_4)2795*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_4) {
2796*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2797*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2798*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2799*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2800*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2801*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2802*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2803*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2804*4bdc9457SAndroid Build Coastguard Worker }
2805*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_1_8_bw_1_8)2806*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_1_8_bw_1_8) {
2807*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2808*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
2809*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2810*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2811*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2812*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2813*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2814*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2815*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2816*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2817*4bdc9457SAndroid Build Coastguard Worker }
2818*4bdc9457SAndroid Build Coastguard Worker }
2819*4bdc9457SAndroid Build Coastguard Worker }
2820*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_8)2821*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_8) {
2822*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2823*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2824*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2825*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2826*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2827*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2828*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2829*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2830*4bdc9457SAndroid Build Coastguard Worker }
2831*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_5_8)2832*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_5_8) {
2833*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2834*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2835*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2836*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2837*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2838*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2839*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2840*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2841*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2842*4bdc9457SAndroid Build Coastguard Worker }
2843*4bdc9457SAndroid Build Coastguard Worker }
2844*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_8_bw_5_8)2845*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_8_bw_5_8) {
2846*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2847*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2848*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2849*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2850*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2851*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2852*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2853*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2855*4bdc9457SAndroid Build Coastguard Worker }
2856*4bdc9457SAndroid Build Coastguard Worker }
2857*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_8_bw_4)2858*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_8_bw_4) {
2859*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2860*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2861*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2862*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2863*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2864*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2865*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2866*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2867*4bdc9457SAndroid Build Coastguard Worker }
2868*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_5_8_bw_4)2869*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_5_8_bw_4){
2870*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2871*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2872*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
2873*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2874*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
2875*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2876*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2877*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2878*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2879*4bdc9457SAndroid Build Coastguard Worker }
2880*4bdc9457SAndroid Build Coastguard Worker }
2881*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_5_8_bw_8)2882*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_5_8_bw_8){
2883*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2884*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2885*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2886*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2887*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2888*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2889*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2890*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2891*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2892*4bdc9457SAndroid Build Coastguard Worker }
2893*4bdc9457SAndroid Build Coastguard Worker }
2894*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_5_8_bw_5_8)2895*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_5_8_bw_5_8) {
2896*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2897*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
2898*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2899*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2900*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2901*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2902*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2903*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2904*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2905*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2906*4bdc9457SAndroid Build Coastguard Worker }
2907*4bdc9457SAndroid Build Coastguard Worker }
2908*4bdc9457SAndroid Build Coastguard Worker }
2909*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_4_is_8)2910*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_4_is_8) {
2911*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2912*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2913*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2914*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2915*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2916*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2917*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2918*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2919*4bdc9457SAndroid Build Coastguard Worker }
2920*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_4_os_8)2921*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_4_os_8) {
2922*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2923*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2924*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2925*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2926*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2927*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2930*4bdc9457SAndroid Build Coastguard Worker }
2931*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_4_bw_4_is_8_os_8)2932*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_4_bw_4_is_8_os_8) {
2933*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2934*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2935*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2936*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2937*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2938*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2939*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2940*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2941*4bdc9457SAndroid Build Coastguard Worker }
2942*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_68_bw_76_ies_15)2943*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_68_bw_76_ies_15) {
2944*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2945*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
2946*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2947*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
2948*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2949*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2950*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
2951*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2952*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2953*4bdc9457SAndroid Build Coastguard Worker }
2954*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_12_bw_20_oes_15)2955*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_12_bw_20_oes_15) {
2956*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2957*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
2958*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2959*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
2960*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2961*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2962*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2963*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2964*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2965*4bdc9457SAndroid Build Coastguard Worker }
2966*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4,bh_28_bw_92_ies_21_oes_17)2967*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SCALAR_INT_4, bh_28_bw_92_ies_21_oes_17) {
2968*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2969*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
2970*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2971*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
2972*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2973*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2974*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
2975*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
2976*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2977*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_scalar_int);
2978*4bdc9457SAndroid Build Coastguard Worker }
2979*4bdc9457SAndroid Build Coastguard Worker
2980*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_4)2981*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_4) {
2982*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
2983*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2984*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2985*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2986*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2987*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2988*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
2989*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2990*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
2991*4bdc9457SAndroid Build Coastguard Worker }
2992*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_1_8_bw_1_8)2993*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_1_8_bw_1_8) {
2994*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
2995*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
2996*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
2997*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2998*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2999*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3000*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3001*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3002*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3003*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3005*4bdc9457SAndroid Build Coastguard Worker }
3006*4bdc9457SAndroid Build Coastguard Worker }
3007*4bdc9457SAndroid Build Coastguard Worker }
3008*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_8)3009*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_8) {
3010*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3011*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3012*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3013*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3014*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3015*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3016*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3017*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3018*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3019*4bdc9457SAndroid Build Coastguard Worker }
3020*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_5_8)3021*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_5_8) {
3022*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3023*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3024*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3025*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3026*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3027*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3028*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3029*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3030*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3031*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3032*4bdc9457SAndroid Build Coastguard Worker }
3033*4bdc9457SAndroid Build Coastguard Worker }
3034*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_8_bw_5_8)3035*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_8_bw_5_8) {
3036*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3037*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3038*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3039*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3040*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3041*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3042*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3043*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3044*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3045*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3046*4bdc9457SAndroid Build Coastguard Worker }
3047*4bdc9457SAndroid Build Coastguard Worker }
3048*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_8_bw_4)3049*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_8_bw_4) {
3050*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3051*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3052*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3053*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3054*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3055*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3056*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3057*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3058*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3059*4bdc9457SAndroid Build Coastguard Worker }
3060*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_5_8_bw_4)3061*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_5_8_bw_4){
3062*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3063*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3064*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3065*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3066*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3067*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3068*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3069*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3070*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3071*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3072*4bdc9457SAndroid Build Coastguard Worker }
3073*4bdc9457SAndroid Build Coastguard Worker }
3074*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_5_8_bw_8)3075*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_5_8_bw_8){
3076*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3077*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3078*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3079*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3080*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3081*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3082*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3083*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3084*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3085*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3086*4bdc9457SAndroid Build Coastguard Worker }
3087*4bdc9457SAndroid Build Coastguard Worker }
3088*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_5_8_bw_5_8)3089*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_5_8_bw_5_8) {
3090*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3091*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3092*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3093*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3094*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3095*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3096*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3097*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3098*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3099*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3100*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3101*4bdc9457SAndroid Build Coastguard Worker }
3102*4bdc9457SAndroid Build Coastguard Worker }
3103*4bdc9457SAndroid Build Coastguard Worker }
3104*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_4_is_8)3105*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_4_is_8) {
3106*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3107*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3108*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3109*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3110*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3111*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3112*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3113*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3115*4bdc9457SAndroid Build Coastguard Worker }
3116*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_4_os_8)3117*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_4_os_8) {
3118*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3119*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3120*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3121*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3122*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3123*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3124*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3125*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3126*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3127*4bdc9457SAndroid Build Coastguard Worker }
3128*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_4_bw_4_is_8_os_8)3129*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_4_bw_4_is_8_os_8) {
3130*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3131*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3132*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3133*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3134*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3135*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3136*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3139*4bdc9457SAndroid Build Coastguard Worker }
3140*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_68_bw_76_ies_15)3141*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_68_bw_76_ies_15) {
3142*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3143*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3144*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3145*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3146*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3147*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3148*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3149*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
3150*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3152*4bdc9457SAndroid Build Coastguard Worker }
3153*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_12_bw_20_oes_15)3154*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_12_bw_20_oes_15) {
3155*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3156*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3157*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3158*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3159*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3160*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3161*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3162*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3163*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3165*4bdc9457SAndroid Build Coastguard Worker }
3166*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4,bh_28_bw_92_ies_21_oes_17)3167*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_AARCH64_NEON_TBL_4, bh_28_bw_92_ies_21_oes_17) {
3168*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3169*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3170*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3171*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3172*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3173*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3174*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3175*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
3176*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
3177*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_aarch64_neon_tbl);
3179*4bdc9457SAndroid Build Coastguard Worker }
3180*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM64
3181*4bdc9457SAndroid Build Coastguard Worker
3182*4bdc9457SAndroid Build Coastguard Worker
3183*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_4)3184*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_4) {
3185*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3186*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3187*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3188*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3189*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3190*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3191*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3192*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3193*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3194*4bdc9457SAndroid Build Coastguard Worker }
3195*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_1_8_bw_1_8)3196*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_1_8_bw_1_8) {
3197*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3198*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3199*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3200*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3201*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3202*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3203*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3204*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3205*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3206*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3207*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3208*4bdc9457SAndroid Build Coastguard Worker }
3209*4bdc9457SAndroid Build Coastguard Worker }
3210*4bdc9457SAndroid Build Coastguard Worker }
3211*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_8)3212*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_8) {
3213*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3214*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3215*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3216*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3217*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3218*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3219*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3220*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3221*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3222*4bdc9457SAndroid Build Coastguard Worker }
3223*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_5_8)3224*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_5_8) {
3225*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3226*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3227*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3228*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3229*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3230*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3231*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3232*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3233*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3234*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3235*4bdc9457SAndroid Build Coastguard Worker }
3236*4bdc9457SAndroid Build Coastguard Worker }
3237*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_8_bw_5_8)3238*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_8_bw_5_8) {
3239*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3240*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3241*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3242*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3243*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3244*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3245*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3246*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3247*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3248*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3249*4bdc9457SAndroid Build Coastguard Worker }
3250*4bdc9457SAndroid Build Coastguard Worker }
3251*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_8_bw_4)3252*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_8_bw_4) {
3253*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3254*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3255*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3256*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3257*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3258*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3259*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3260*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3261*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3262*4bdc9457SAndroid Build Coastguard Worker }
3263*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_5_8_bw_4)3264*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_5_8_bw_4){
3265*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3266*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3267*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3268*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3269*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3270*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3271*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3272*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3273*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3274*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3275*4bdc9457SAndroid Build Coastguard Worker }
3276*4bdc9457SAndroid Build Coastguard Worker }
3277*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_5_8_bw_8)3278*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_5_8_bw_8){
3279*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3280*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3281*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3282*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3283*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3284*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3285*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3286*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3287*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3288*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3289*4bdc9457SAndroid Build Coastguard Worker }
3290*4bdc9457SAndroid Build Coastguard Worker }
3291*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_5_8_bw_5_8)3292*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_5_8_bw_5_8) {
3293*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3294*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3295*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3296*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3297*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3298*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3299*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3300*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3301*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3302*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3303*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3304*4bdc9457SAndroid Build Coastguard Worker }
3305*4bdc9457SAndroid Build Coastguard Worker }
3306*4bdc9457SAndroid Build Coastguard Worker }
3307*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_4_is_8)3308*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_4_is_8) {
3309*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3310*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3311*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3312*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3313*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3314*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3315*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3316*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3317*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3318*4bdc9457SAndroid Build Coastguard Worker }
3319*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_4_os_8)3320*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_4_os_8) {
3321*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3322*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3323*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3324*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3325*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3326*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3327*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3328*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3329*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3330*4bdc9457SAndroid Build Coastguard Worker }
3331*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_4_bw_4_is_8_os_8)3332*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_4_bw_4_is_8_os_8) {
3333*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3334*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3335*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3336*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3337*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3338*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3339*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3340*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3341*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3342*4bdc9457SAndroid Build Coastguard Worker }
3343*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_68_bw_76_ies_15)3344*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_68_bw_76_ies_15) {
3345*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3346*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3347*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3348*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3349*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3350*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3351*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3352*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
3353*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3354*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3355*4bdc9457SAndroid Build Coastguard Worker }
3356*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_12_bw_20_oes_15)3357*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_12_bw_20_oes_15) {
3358*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3359*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3360*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3361*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3362*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3363*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3364*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3365*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3366*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3367*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3368*4bdc9457SAndroid Build Coastguard Worker }
3369*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4,bh_28_bw_92_ies_21_oes_17)3370*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
3371*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3372*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3373*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3374*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3375*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3376*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3377*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3378*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
3379*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
3380*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3381*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_sse2);
3382*4bdc9457SAndroid Build Coastguard Worker }
3383*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3384*4bdc9457SAndroid Build Coastguard Worker
3385*4bdc9457SAndroid Build Coastguard Worker
3386*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_4)3387*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_4) {
3388*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3389*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3390*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3391*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3392*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3393*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3394*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3395*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3396*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3397*4bdc9457SAndroid Build Coastguard Worker }
3398*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_1_8_bw_1_8)3399*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_1_8_bw_1_8) {
3400*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3401*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3402*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3403*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3404*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3405*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3406*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3407*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3408*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3409*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3410*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3411*4bdc9457SAndroid Build Coastguard Worker }
3412*4bdc9457SAndroid Build Coastguard Worker }
3413*4bdc9457SAndroid Build Coastguard Worker }
3414*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_8)3415*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_8) {
3416*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3417*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3418*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3419*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3420*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3421*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3422*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3423*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3424*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3425*4bdc9457SAndroid Build Coastguard Worker }
3426*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_5_8)3427*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_5_8) {
3428*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3429*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3430*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3431*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3432*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3433*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3434*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3435*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3436*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3437*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3438*4bdc9457SAndroid Build Coastguard Worker }
3439*4bdc9457SAndroid Build Coastguard Worker }
3440*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_8_bw_5_8)3441*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_8_bw_5_8) {
3442*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3443*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3444*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3445*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3446*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3447*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3448*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3449*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3450*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3451*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3452*4bdc9457SAndroid Build Coastguard Worker }
3453*4bdc9457SAndroid Build Coastguard Worker }
3454*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_8_bw_4)3455*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_8_bw_4) {
3456*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3457*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3458*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3459*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3460*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3461*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3462*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3463*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3464*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3465*4bdc9457SAndroid Build Coastguard Worker }
3466*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_5_8_bw_4)3467*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_5_8_bw_4){
3468*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3469*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3470*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3471*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3472*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3473*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3474*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3475*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3476*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3477*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3478*4bdc9457SAndroid Build Coastguard Worker }
3479*4bdc9457SAndroid Build Coastguard Worker }
3480*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_5_8_bw_8)3481*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_5_8_bw_8){
3482*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3483*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3484*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3485*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3486*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3487*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3488*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3489*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3490*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3491*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3492*4bdc9457SAndroid Build Coastguard Worker }
3493*4bdc9457SAndroid Build Coastguard Worker }
3494*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_5_8_bw_5_8)3495*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_5_8_bw_5_8) {
3496*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3497*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3498*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3499*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3500*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3501*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3502*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3503*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3504*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3505*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3506*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3507*4bdc9457SAndroid Build Coastguard Worker }
3508*4bdc9457SAndroid Build Coastguard Worker }
3509*4bdc9457SAndroid Build Coastguard Worker }
3510*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_4_is_8)3511*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_4_is_8) {
3512*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3513*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3514*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3515*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3516*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3517*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3518*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3519*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3520*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3521*4bdc9457SAndroid Build Coastguard Worker }
3522*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_4_os_8)3523*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_4_os_8) {
3524*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3525*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3526*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3527*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3528*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3529*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3530*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3531*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3532*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3533*4bdc9457SAndroid Build Coastguard Worker }
3534*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_4_bw_4_is_8_os_8)3535*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_4_bw_4_is_8_os_8) {
3536*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3537*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3538*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3539*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3540*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3541*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3542*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3543*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3544*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3545*4bdc9457SAndroid Build Coastguard Worker }
3546*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_68_bw_76_ies_15)3547*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_68_bw_76_ies_15) {
3548*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3549*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3550*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3551*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3552*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3553*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3554*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3555*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
3556*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3557*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3558*4bdc9457SAndroid Build Coastguard Worker }
3559*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_12_bw_20_oes_15)3560*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_12_bw_20_oes_15) {
3561*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3562*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3563*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3564*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3565*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3566*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3567*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3568*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3569*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3570*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3571*4bdc9457SAndroid Build Coastguard Worker }
3572*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4,bh_28_bw_92_ies_21_oes_17)3573*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
3574*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3575*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3576*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3577*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3578*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3579*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3580*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3581*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
3582*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
3583*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3584*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_sse2);
3585*4bdc9457SAndroid Build Coastguard Worker }
3586*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3587*4bdc9457SAndroid Build Coastguard Worker
3588*4bdc9457SAndroid Build Coastguard Worker
3589*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_4)3590*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_4) {
3591*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3592*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3593*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3594*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3595*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3596*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3597*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3598*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3599*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3600*4bdc9457SAndroid Build Coastguard Worker }
3601*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_1_8_bw_1_8)3602*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_1_8_bw_1_8) {
3603*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3604*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3605*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3606*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3607*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3608*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3609*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3610*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3611*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3612*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3613*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3614*4bdc9457SAndroid Build Coastguard Worker }
3615*4bdc9457SAndroid Build Coastguard Worker }
3616*4bdc9457SAndroid Build Coastguard Worker }
3617*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_8)3618*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_8) {
3619*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3620*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3621*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3622*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3623*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3624*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3625*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3626*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3627*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3628*4bdc9457SAndroid Build Coastguard Worker }
3629*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_5_8)3630*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_5_8) {
3631*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3632*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3633*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3634*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3635*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3636*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3637*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3638*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3639*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3640*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3641*4bdc9457SAndroid Build Coastguard Worker }
3642*4bdc9457SAndroid Build Coastguard Worker }
3643*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_8_bw_5_8)3644*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_8_bw_5_8) {
3645*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3646*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3647*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3648*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3649*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3650*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3651*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3652*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3653*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3654*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3655*4bdc9457SAndroid Build Coastguard Worker }
3656*4bdc9457SAndroid Build Coastguard Worker }
3657*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_8_bw_4)3658*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_8_bw_4) {
3659*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3660*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3661*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3662*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3663*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3664*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3665*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3666*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3667*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3668*4bdc9457SAndroid Build Coastguard Worker }
3669*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_5_8_bw_4)3670*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_5_8_bw_4){
3671*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3672*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3673*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3674*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3675*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3676*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3677*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3678*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3679*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3680*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3681*4bdc9457SAndroid Build Coastguard Worker }
3682*4bdc9457SAndroid Build Coastguard Worker }
3683*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_5_8_bw_8)3684*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_5_8_bw_8){
3685*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3686*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3687*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3688*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3689*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3690*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3691*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3692*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3693*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3694*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3695*4bdc9457SAndroid Build Coastguard Worker }
3696*4bdc9457SAndroid Build Coastguard Worker }
3697*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_5_8_bw_5_8)3698*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_5_8_bw_5_8) {
3699*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3700*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3701*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3702*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3703*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3704*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3705*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3706*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3707*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3708*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3709*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3710*4bdc9457SAndroid Build Coastguard Worker }
3711*4bdc9457SAndroid Build Coastguard Worker }
3712*4bdc9457SAndroid Build Coastguard Worker }
3713*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_4_is_8)3714*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_4_is_8) {
3715*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3716*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3717*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3718*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3719*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3720*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3721*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3722*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3723*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3724*4bdc9457SAndroid Build Coastguard Worker }
3725*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_4_os_8)3726*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_4_os_8) {
3727*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3728*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3729*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3730*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3731*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3732*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3733*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3734*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3735*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3736*4bdc9457SAndroid Build Coastguard Worker }
3737*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_4_bw_4_is_8_os_8)3738*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_4_bw_4_is_8_os_8) {
3739*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3740*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3741*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3742*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3743*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3744*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3745*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3746*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3747*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3748*4bdc9457SAndroid Build Coastguard Worker }
3749*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_68_bw_76_ies_15)3750*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_68_bw_76_ies_15) {
3751*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3752*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3753*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3754*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3755*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3756*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3757*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3758*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
3759*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3760*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3761*4bdc9457SAndroid Build Coastguard Worker }
3762*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_12_bw_20_oes_15)3763*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_12_bw_20_oes_15) {
3764*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3765*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3766*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3767*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3768*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3769*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3770*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3771*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3772*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3773*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3774*4bdc9457SAndroid Build Coastguard Worker }
3775*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4,bh_28_bw_92_ies_21_oes_17)3776*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
3777*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3778*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3779*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3780*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3781*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3782*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3783*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3784*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
3785*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
3786*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3787*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_sse2);
3788*4bdc9457SAndroid Build Coastguard Worker }
3789*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3790*4bdc9457SAndroid Build Coastguard Worker
3791*4bdc9457SAndroid Build Coastguard Worker
3792*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_4)3793*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_4) {
3794*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3795*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3796*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3797*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3798*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3799*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3800*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3801*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3802*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3803*4bdc9457SAndroid Build Coastguard Worker }
3804*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_1_8_bw_1_8)3805*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_1_8_bw_1_8) {
3806*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3807*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3808*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3809*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3810*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3811*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3812*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3813*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3814*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3815*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3816*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3817*4bdc9457SAndroid Build Coastguard Worker }
3818*4bdc9457SAndroid Build Coastguard Worker }
3819*4bdc9457SAndroid Build Coastguard Worker }
3820*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_8)3821*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_8) {
3822*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3823*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3824*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3825*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3826*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3827*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3828*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3829*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3830*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3831*4bdc9457SAndroid Build Coastguard Worker }
3832*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_5_8)3833*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_5_8) {
3834*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3835*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3836*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3837*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3838*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3839*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3840*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3841*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3842*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3843*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3844*4bdc9457SAndroid Build Coastguard Worker }
3845*4bdc9457SAndroid Build Coastguard Worker }
3846*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_8_bw_5_8)3847*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_8_bw_5_8) {
3848*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3849*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3850*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3851*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3852*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3853*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3854*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3855*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3856*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3857*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3858*4bdc9457SAndroid Build Coastguard Worker }
3859*4bdc9457SAndroid Build Coastguard Worker }
3860*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_8_bw_4)3861*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_8_bw_4) {
3862*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3863*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3864*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3865*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3866*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3867*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3868*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3869*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3870*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3871*4bdc9457SAndroid Build Coastguard Worker }
3872*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_5_8_bw_4)3873*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_5_8_bw_4){
3874*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3875*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3876*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3877*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3878*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3879*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3880*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3881*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3882*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3883*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3884*4bdc9457SAndroid Build Coastguard Worker }
3885*4bdc9457SAndroid Build Coastguard Worker }
3886*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_5_8_bw_8)3887*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_5_8_bw_8){
3888*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3889*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3890*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3891*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3892*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3893*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3894*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3895*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3896*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3897*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3898*4bdc9457SAndroid Build Coastguard Worker }
3899*4bdc9457SAndroid Build Coastguard Worker }
3900*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_5_8_bw_5_8)3901*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_5_8_bw_5_8) {
3902*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3903*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3904*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3905*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3906*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3907*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3908*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3909*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3910*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3911*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3912*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3913*4bdc9457SAndroid Build Coastguard Worker }
3914*4bdc9457SAndroid Build Coastguard Worker }
3915*4bdc9457SAndroid Build Coastguard Worker }
3916*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_4_is_8)3917*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_4_is_8) {
3918*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3919*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3920*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3921*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3922*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3923*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3924*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3925*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3926*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3927*4bdc9457SAndroid Build Coastguard Worker }
3928*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_4_os_8)3929*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_4_os_8) {
3930*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3931*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3932*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3933*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3934*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3935*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3936*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3937*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3938*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3939*4bdc9457SAndroid Build Coastguard Worker }
3940*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_4_bw_4_is_8_os_8)3941*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_4_bw_4_is_8_os_8) {
3942*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3943*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3944*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3945*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3946*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3947*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3948*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3949*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3950*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3951*4bdc9457SAndroid Build Coastguard Worker }
3952*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_68_bw_76_ies_15)3953*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_68_bw_76_ies_15) {
3954*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3955*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3956*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3957*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3958*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3959*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3960*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3961*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
3962*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3963*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3964*4bdc9457SAndroid Build Coastguard Worker }
3965*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_12_bw_20_oes_15)3966*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_12_bw_20_oes_15) {
3967*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3968*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3969*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3970*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3971*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3972*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3973*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3974*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3975*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3976*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3977*4bdc9457SAndroid Build Coastguard Worker }
3978*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4,bh_28_bw_92_ies_21_oes_17)3979*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
3980*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3981*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3982*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3983*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3984*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3985*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3986*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
3987*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
3988*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
3989*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3990*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_sse2);
3991*4bdc9457SAndroid Build Coastguard Worker }
3992*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3993*4bdc9457SAndroid Build Coastguard Worker
3994*4bdc9457SAndroid Build Coastguard Worker
3995*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_4)3996*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_4) {
3997*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
3998*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3999*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4000*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4001*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4002*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4003*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4004*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4005*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4006*4bdc9457SAndroid Build Coastguard Worker }
4007*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_1_8_bw_1_8)4008*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_1_8_bw_1_8) {
4009*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4010*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4011*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4012*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4013*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4014*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4015*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4016*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4017*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4018*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4019*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4020*4bdc9457SAndroid Build Coastguard Worker }
4021*4bdc9457SAndroid Build Coastguard Worker }
4022*4bdc9457SAndroid Build Coastguard Worker }
4023*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_8)4024*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_8) {
4025*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4026*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4027*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4028*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4029*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4030*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4031*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4032*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4033*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4034*4bdc9457SAndroid Build Coastguard Worker }
4035*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_5_8)4036*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_5_8) {
4037*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4038*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4039*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4040*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4041*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4042*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4043*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4044*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4045*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4046*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4047*4bdc9457SAndroid Build Coastguard Worker }
4048*4bdc9457SAndroid Build Coastguard Worker }
4049*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_8_bw_5_8)4050*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_8_bw_5_8) {
4051*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4052*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4053*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4054*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4055*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4056*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4057*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4058*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4059*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4060*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4061*4bdc9457SAndroid Build Coastguard Worker }
4062*4bdc9457SAndroid Build Coastguard Worker }
4063*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_8_bw_4)4064*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_8_bw_4) {
4065*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4066*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4067*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4068*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4069*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4070*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4071*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4072*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4073*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4074*4bdc9457SAndroid Build Coastguard Worker }
4075*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_5_8_bw_4)4076*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_5_8_bw_4){
4077*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4078*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4079*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4080*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4081*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4082*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4083*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4084*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4085*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4086*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4087*4bdc9457SAndroid Build Coastguard Worker }
4088*4bdc9457SAndroid Build Coastguard Worker }
4089*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_5_8_bw_8)4090*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_5_8_bw_8){
4091*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4092*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4093*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4094*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4095*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4096*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4097*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4098*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4099*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4100*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4101*4bdc9457SAndroid Build Coastguard Worker }
4102*4bdc9457SAndroid Build Coastguard Worker }
4103*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_5_8_bw_5_8)4104*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_5_8_bw_5_8) {
4105*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4106*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4107*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4108*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4109*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4110*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4111*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4112*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4113*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4114*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4115*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4116*4bdc9457SAndroid Build Coastguard Worker }
4117*4bdc9457SAndroid Build Coastguard Worker }
4118*4bdc9457SAndroid Build Coastguard Worker }
4119*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_4_is_8)4120*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_4_is_8) {
4121*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4122*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4123*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4124*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4125*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4126*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4127*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4128*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4129*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4130*4bdc9457SAndroid Build Coastguard Worker }
4131*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_4_os_8)4132*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_4_os_8) {
4133*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4134*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4135*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4136*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4137*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4138*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4139*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4140*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4141*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4142*4bdc9457SAndroid Build Coastguard Worker }
4143*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_4_bw_4_is_8_os_8)4144*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_4_bw_4_is_8_os_8) {
4145*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4146*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4147*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4148*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4149*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4150*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4151*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4152*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4153*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4154*4bdc9457SAndroid Build Coastguard Worker }
4155*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_68_bw_76_ies_15)4156*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_68_bw_76_ies_15) {
4157*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4158*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4159*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4160*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4161*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4162*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4163*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4164*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
4165*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4166*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4167*4bdc9457SAndroid Build Coastguard Worker }
4168*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_12_bw_20_oes_15)4169*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_12_bw_20_oes_15) {
4170*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4171*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4172*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4173*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4174*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4175*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4176*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4177*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4178*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4179*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4180*4bdc9457SAndroid Build Coastguard Worker }
4181*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4,bh_28_bw_92_ies_21_oes_17)4182*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
4183*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4184*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4185*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4186*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4187*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4188*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4189*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4190*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
4191*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
4192*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4193*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_sse2);
4194*4bdc9457SAndroid Build Coastguard Worker }
4195*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
4196*4bdc9457SAndroid Build Coastguard Worker
4197*4bdc9457SAndroid Build Coastguard Worker
4198*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_4)4199*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_4) {
4200*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4201*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4202*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4203*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4204*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4205*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4206*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4207*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4208*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4209*4bdc9457SAndroid Build Coastguard Worker }
4210*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_1_8_bw_1_8)4211*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_1_8_bw_1_8) {
4212*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4213*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4214*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4215*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4216*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4217*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4218*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4219*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4220*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4221*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4222*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4223*4bdc9457SAndroid Build Coastguard Worker }
4224*4bdc9457SAndroid Build Coastguard Worker }
4225*4bdc9457SAndroid Build Coastguard Worker }
4226*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_8)4227*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_8) {
4228*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4229*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4230*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4231*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4232*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4233*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4234*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4235*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4236*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4237*4bdc9457SAndroid Build Coastguard Worker }
4238*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_5_8)4239*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_5_8) {
4240*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4241*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4242*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4243*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4244*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4245*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4246*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4247*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4248*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4249*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4250*4bdc9457SAndroid Build Coastguard Worker }
4251*4bdc9457SAndroid Build Coastguard Worker }
4252*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_8_bw_5_8)4253*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_8_bw_5_8) {
4254*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4255*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4256*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4257*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4258*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4259*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4260*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4261*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4262*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4263*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4264*4bdc9457SAndroid Build Coastguard Worker }
4265*4bdc9457SAndroid Build Coastguard Worker }
4266*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_8_bw_4)4267*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_8_bw_4) {
4268*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4269*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4270*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4271*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4272*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4273*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4274*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4275*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4276*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4277*4bdc9457SAndroid Build Coastguard Worker }
4278*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_5_8_bw_4)4279*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_5_8_bw_4){
4280*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4281*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4282*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4283*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4284*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4285*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4286*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4287*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4288*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4289*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4290*4bdc9457SAndroid Build Coastguard Worker }
4291*4bdc9457SAndroid Build Coastguard Worker }
4292*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_5_8_bw_8)4293*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_5_8_bw_8){
4294*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4295*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4296*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4297*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4298*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4299*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4300*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4301*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4302*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4303*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4304*4bdc9457SAndroid Build Coastguard Worker }
4305*4bdc9457SAndroid Build Coastguard Worker }
4306*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_5_8_bw_5_8)4307*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_5_8_bw_5_8) {
4308*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4309*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4310*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4311*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4312*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4313*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4314*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4315*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4316*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4317*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4318*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4319*4bdc9457SAndroid Build Coastguard Worker }
4320*4bdc9457SAndroid Build Coastguard Worker }
4321*4bdc9457SAndroid Build Coastguard Worker }
4322*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_4_is_8)4323*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_4_is_8) {
4324*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4325*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4326*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4327*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4328*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4329*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4330*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4331*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4332*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4333*4bdc9457SAndroid Build Coastguard Worker }
4334*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_4_os_8)4335*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_4_os_8) {
4336*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4337*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4338*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4339*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4340*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4341*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4342*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4343*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4344*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4345*4bdc9457SAndroid Build Coastguard Worker }
4346*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_4_bw_4_is_8_os_8)4347*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_4_bw_4_is_8_os_8) {
4348*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4349*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4350*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4351*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4352*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4353*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4354*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4355*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4356*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4357*4bdc9457SAndroid Build Coastguard Worker }
4358*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_68_bw_76_ies_15)4359*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_68_bw_76_ies_15) {
4360*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4361*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4362*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4363*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4364*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4365*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4366*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4367*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
4368*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4369*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4370*4bdc9457SAndroid Build Coastguard Worker }
4371*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_12_bw_20_oes_15)4372*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_12_bw_20_oes_15) {
4373*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4374*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4375*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4376*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4377*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4378*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4379*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4380*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4381*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4382*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4383*4bdc9457SAndroid Build Coastguard Worker }
4384*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4,bh_28_bw_92_ies_21_oes_17)4385*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_SSE2_4, bh_28_bw_92_ies_21_oes_17) {
4386*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
4387*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4388*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4389*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4390*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4391*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4392*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4393*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
4394*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
4395*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4396*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_sse2);
4397*4bdc9457SAndroid Build Coastguard Worker }
4398*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
4399*4bdc9457SAndroid Build Coastguard Worker
4400*4bdc9457SAndroid Build Coastguard Worker
4401*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_4)4402*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_4) {
4403*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4404*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4405*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4406*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4407*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4408*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4409*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4412*4bdc9457SAndroid Build Coastguard Worker }
4413*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_1_8_bw_1_8)4414*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_1_8_bw_1_8) {
4415*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4416*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4417*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4418*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4419*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4420*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4421*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4422*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4423*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4424*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4425*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4426*4bdc9457SAndroid Build Coastguard Worker }
4427*4bdc9457SAndroid Build Coastguard Worker }
4428*4bdc9457SAndroid Build Coastguard Worker }
4429*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_8)4430*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_8) {
4431*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4432*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4433*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4434*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4435*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4436*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4437*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4438*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4439*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4440*4bdc9457SAndroid Build Coastguard Worker }
4441*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_5_8)4442*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_5_8) {
4443*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4444*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4445*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4446*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4447*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4448*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4449*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4450*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4451*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4452*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4453*4bdc9457SAndroid Build Coastguard Worker }
4454*4bdc9457SAndroid Build Coastguard Worker }
4455*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_8_bw_5_8)4456*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_8_bw_5_8) {
4457*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4458*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4459*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4460*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4461*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4462*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4463*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4464*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4465*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4466*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4467*4bdc9457SAndroid Build Coastguard Worker }
4468*4bdc9457SAndroid Build Coastguard Worker }
4469*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_8_bw_4)4470*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_8_bw_4) {
4471*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4472*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4473*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4474*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4475*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4476*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4477*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4478*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4479*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4480*4bdc9457SAndroid Build Coastguard Worker }
4481*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_5_8_bw_4)4482*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_5_8_bw_4){
4483*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4484*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4485*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4486*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4487*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4488*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4489*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4490*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4491*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4492*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4493*4bdc9457SAndroid Build Coastguard Worker }
4494*4bdc9457SAndroid Build Coastguard Worker }
4495*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_5_8_bw_8)4496*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_5_8_bw_8){
4497*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4498*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4499*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4500*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4501*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4502*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4503*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4504*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4505*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4506*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4507*4bdc9457SAndroid Build Coastguard Worker }
4508*4bdc9457SAndroid Build Coastguard Worker }
4509*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_5_8_bw_5_8)4510*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_5_8_bw_5_8) {
4511*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4512*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4513*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4514*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4515*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4516*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4517*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4518*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4519*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4520*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4521*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4522*4bdc9457SAndroid Build Coastguard Worker }
4523*4bdc9457SAndroid Build Coastguard Worker }
4524*4bdc9457SAndroid Build Coastguard Worker }
4525*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_4_is_8)4526*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_4_is_8) {
4527*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4528*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4529*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4530*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4531*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4532*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4533*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4536*4bdc9457SAndroid Build Coastguard Worker }
4537*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_4_os_8)4538*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_4_os_8) {
4539*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4540*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4541*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4542*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4543*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4544*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4545*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4546*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4547*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4548*4bdc9457SAndroid Build Coastguard Worker }
4549*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_4_bw_4_is_8_os_8)4550*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_4_bw_4_is_8_os_8) {
4551*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4552*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4553*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4554*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4555*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4556*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4557*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4560*4bdc9457SAndroid Build Coastguard Worker }
4561*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_68_bw_76_ies_15)4562*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_68_bw_76_ies_15) {
4563*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4564*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4565*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4566*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4567*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4568*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4569*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4570*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
4571*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4572*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4573*4bdc9457SAndroid Build Coastguard Worker }
4574*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_12_bw_20_oes_15)4575*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_12_bw_20_oes_15) {
4576*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4577*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4578*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4579*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4580*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4581*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4582*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4583*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4584*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4585*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4586*4bdc9457SAndroid Build Coastguard Worker }
4587*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_SSE_4,bh_28_bw_92_ies_21_oes_17)4588*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_SSE_4, bh_28_bw_92_ies_21_oes_17) {
4589*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE;
4590*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4591*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4592*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4593*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4594*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4595*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4596*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
4597*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
4598*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4599*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_sse);
4600*4bdc9457SAndroid Build Coastguard Worker }
4601*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
4602*4bdc9457SAndroid Build Coastguard Worker
4603*4bdc9457SAndroid Build Coastguard Worker
4604*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_4)4605*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_4) {
4606*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4607*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4608*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4609*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4610*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4611*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4612*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4613*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4614*4bdc9457SAndroid Build Coastguard Worker }
4615*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_1_8_bw_1_8)4616*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_1_8_bw_1_8) {
4617*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4618*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4619*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4620*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4621*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4622*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4623*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4624*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4625*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4626*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4627*4bdc9457SAndroid Build Coastguard Worker }
4628*4bdc9457SAndroid Build Coastguard Worker }
4629*4bdc9457SAndroid Build Coastguard Worker }
4630*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_8)4631*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_8) {
4632*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4633*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4634*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4635*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4636*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4637*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4638*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4639*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4640*4bdc9457SAndroid Build Coastguard Worker }
4641*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_5_8)4642*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_5_8) {
4643*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4644*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4645*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4646*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4647*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4648*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4649*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4650*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4651*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4652*4bdc9457SAndroid Build Coastguard Worker }
4653*4bdc9457SAndroid Build Coastguard Worker }
4654*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_8_bw_5_8)4655*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_8_bw_5_8) {
4656*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4657*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4658*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4659*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4660*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4661*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4662*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4663*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4664*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4665*4bdc9457SAndroid Build Coastguard Worker }
4666*4bdc9457SAndroid Build Coastguard Worker }
4667*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_8_bw_4)4668*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_8_bw_4) {
4669*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4670*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4671*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4672*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4673*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4674*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4675*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4676*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4677*4bdc9457SAndroid Build Coastguard Worker }
4678*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_5_8_bw_4)4679*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_5_8_bw_4){
4680*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4681*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4682*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4683*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4684*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4685*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4686*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4687*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4688*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4689*4bdc9457SAndroid Build Coastguard Worker }
4690*4bdc9457SAndroid Build Coastguard Worker }
4691*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_5_8_bw_8)4692*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_5_8_bw_8){
4693*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4694*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4695*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4696*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4697*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4698*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4699*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4700*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4701*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4702*4bdc9457SAndroid Build Coastguard Worker }
4703*4bdc9457SAndroid Build Coastguard Worker }
4704*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_5_8_bw_5_8)4705*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_5_8_bw_5_8) {
4706*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4707*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4708*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4709*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4710*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4711*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4712*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4713*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4714*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4715*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4716*4bdc9457SAndroid Build Coastguard Worker }
4717*4bdc9457SAndroid Build Coastguard Worker }
4718*4bdc9457SAndroid Build Coastguard Worker }
4719*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_4_is_8)4720*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_4_is_8) {
4721*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4722*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4723*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4724*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4725*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4726*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4727*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4729*4bdc9457SAndroid Build Coastguard Worker }
4730*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_4_os_8)4731*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_4_os_8) {
4732*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4733*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4734*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4735*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4736*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4737*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4738*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4739*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4740*4bdc9457SAndroid Build Coastguard Worker }
4741*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_4_bw_4_is_8_os_8)4742*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
4743*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4744*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4745*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4746*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4747*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4748*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4749*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4750*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4751*4bdc9457SAndroid Build Coastguard Worker }
4752*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_68_bw_76_ies_15)4753*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_68_bw_76_ies_15) {
4754*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4755*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4756*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4757*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4758*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4759*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4760*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
4761*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4762*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4763*4bdc9457SAndroid Build Coastguard Worker }
4764*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_12_bw_20_oes_15)4765*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_12_bw_20_oes_15) {
4766*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4767*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4768*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4769*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4770*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4771*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4772*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4773*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4774*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4775*4bdc9457SAndroid Build Coastguard Worker }
4776*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)4777*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
4778*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4779*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4780*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4781*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4782*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4783*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4784*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
4785*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
4786*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4787*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_wasmsimd);
4788*4bdc9457SAndroid Build Coastguard Worker }
4789*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
4790*4bdc9457SAndroid Build Coastguard Worker
4791*4bdc9457SAndroid Build Coastguard Worker
4792*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_4)4793*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_4) {
4794*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4795*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4796*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4797*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4798*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4799*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4800*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4801*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4802*4bdc9457SAndroid Build Coastguard Worker }
4803*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_1_8_bw_1_8)4804*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_1_8_bw_1_8) {
4805*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4806*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4807*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4808*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4809*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4810*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4811*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4812*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4813*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4814*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4815*4bdc9457SAndroid Build Coastguard Worker }
4816*4bdc9457SAndroid Build Coastguard Worker }
4817*4bdc9457SAndroid Build Coastguard Worker }
4818*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_8)4819*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_8) {
4820*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4821*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4822*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4823*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4824*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4825*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4826*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4827*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4828*4bdc9457SAndroid Build Coastguard Worker }
4829*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_5_8)4830*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_5_8) {
4831*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4832*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4833*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4834*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4835*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4836*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4837*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4838*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4839*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4840*4bdc9457SAndroid Build Coastguard Worker }
4841*4bdc9457SAndroid Build Coastguard Worker }
4842*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_8_bw_5_8)4843*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_8_bw_5_8) {
4844*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4845*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4846*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4847*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4848*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4849*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4850*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4851*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4852*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4853*4bdc9457SAndroid Build Coastguard Worker }
4854*4bdc9457SAndroid Build Coastguard Worker }
4855*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_8_bw_4)4856*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_8_bw_4) {
4857*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4858*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4859*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4860*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4861*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4862*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4863*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4864*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4865*4bdc9457SAndroid Build Coastguard Worker }
4866*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_5_8_bw_4)4867*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_5_8_bw_4){
4868*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4869*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4870*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4871*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4872*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4873*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4874*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4875*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4876*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4877*4bdc9457SAndroid Build Coastguard Worker }
4878*4bdc9457SAndroid Build Coastguard Worker }
4879*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_5_8_bw_8)4880*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_5_8_bw_8){
4881*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4882*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4883*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4884*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4885*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4886*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4887*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4888*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4889*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4890*4bdc9457SAndroid Build Coastguard Worker }
4891*4bdc9457SAndroid Build Coastguard Worker }
4892*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_5_8_bw_5_8)4893*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_5_8_bw_5_8) {
4894*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4895*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4896*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4897*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4898*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4899*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4900*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4901*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4902*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4903*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4904*4bdc9457SAndroid Build Coastguard Worker }
4905*4bdc9457SAndroid Build Coastguard Worker }
4906*4bdc9457SAndroid Build Coastguard Worker }
4907*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_4_is_8)4908*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_4_is_8) {
4909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4910*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4911*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4912*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4913*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4914*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4917*4bdc9457SAndroid Build Coastguard Worker }
4918*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_4_os_8)4919*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_4_os_8) {
4920*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4921*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4922*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4923*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4924*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4925*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4926*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4927*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4928*4bdc9457SAndroid Build Coastguard Worker }
4929*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_4_bw_4_is_8_os_8)4930*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
4931*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4932*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4933*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4934*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4935*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4936*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4937*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4938*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4939*4bdc9457SAndroid Build Coastguard Worker }
4940*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_68_bw_76_ies_15)4941*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_68_bw_76_ies_15) {
4942*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4943*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4944*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4945*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4946*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4947*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4948*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
4949*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4950*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4951*4bdc9457SAndroid Build Coastguard Worker }
4952*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_12_bw_20_oes_15)4953*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_12_bw_20_oes_15) {
4954*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4955*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4956*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4957*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4958*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4959*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4960*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4961*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4962*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4963*4bdc9457SAndroid Build Coastguard Worker }
4964*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)4965*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
4966*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4967*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4968*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4969*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4970*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4971*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4972*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
4973*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
4974*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4975*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_wasmsimd);
4976*4bdc9457SAndroid Build Coastguard Worker }
4977*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
4978*4bdc9457SAndroid Build Coastguard Worker
4979*4bdc9457SAndroid Build Coastguard Worker
4980*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_4)4981*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_4) {
4982*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4983*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4984*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4985*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4986*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4987*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
4988*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4989*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
4990*4bdc9457SAndroid Build Coastguard Worker }
4991*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_1_8_bw_1_8)4992*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_1_8_bw_1_8) {
4993*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4994*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4995*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4996*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4997*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4998*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4999*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5000*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5001*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5002*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5003*4bdc9457SAndroid Build Coastguard Worker }
5004*4bdc9457SAndroid Build Coastguard Worker }
5005*4bdc9457SAndroid Build Coastguard Worker }
5006*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_8)5007*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_8) {
5008*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5009*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5010*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5011*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5012*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5013*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5014*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5015*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5016*4bdc9457SAndroid Build Coastguard Worker }
5017*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_5_8)5018*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_5_8) {
5019*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5020*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5021*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5022*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5023*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5024*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5025*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5026*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5027*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5028*4bdc9457SAndroid Build Coastguard Worker }
5029*4bdc9457SAndroid Build Coastguard Worker }
5030*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_8_bw_5_8)5031*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_8_bw_5_8) {
5032*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5033*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5034*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5035*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5036*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5037*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5038*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5039*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5041*4bdc9457SAndroid Build Coastguard Worker }
5042*4bdc9457SAndroid Build Coastguard Worker }
5043*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_8_bw_4)5044*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_8_bw_4) {
5045*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5046*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5047*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5048*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5049*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5050*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5053*4bdc9457SAndroid Build Coastguard Worker }
5054*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_5_8_bw_4)5055*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_5_8_bw_4){
5056*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5057*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5058*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
5059*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5060*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
5061*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5062*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5063*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5065*4bdc9457SAndroid Build Coastguard Worker }
5066*4bdc9457SAndroid Build Coastguard Worker }
5067*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_5_8_bw_8)5068*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_5_8_bw_8){
5069*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5070*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5071*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5072*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5073*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5074*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5075*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5076*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5077*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5078*4bdc9457SAndroid Build Coastguard Worker }
5079*4bdc9457SAndroid Build Coastguard Worker }
5080*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_5_8_bw_5_8)5081*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_5_8_bw_5_8) {
5082*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5083*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
5084*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5085*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5086*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5087*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5088*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5089*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5090*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5091*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5092*4bdc9457SAndroid Build Coastguard Worker }
5093*4bdc9457SAndroid Build Coastguard Worker }
5094*4bdc9457SAndroid Build Coastguard Worker }
5095*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_4_is_8)5096*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_4_is_8) {
5097*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5098*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5099*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5100*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5101*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5102*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5103*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5105*4bdc9457SAndroid Build Coastguard Worker }
5106*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_4_os_8)5107*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_4_os_8) {
5108*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5109*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5110*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5111*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5112*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5113*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5114*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5115*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5116*4bdc9457SAndroid Build Coastguard Worker }
5117*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_4_bw_4_is_8_os_8)5118*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
5119*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5120*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5121*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5122*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5123*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5124*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5125*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5126*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5127*4bdc9457SAndroid Build Coastguard Worker }
5128*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_68_bw_76_ies_15)5129*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_68_bw_76_ies_15) {
5130*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5131*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
5132*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
5133*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
5134*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
5135*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5136*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
5137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5139*4bdc9457SAndroid Build Coastguard Worker }
5140*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_12_bw_20_oes_15)5141*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_12_bw_20_oes_15) {
5142*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5143*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
5144*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
5145*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
5146*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
5147*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5148*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5149*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5150*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5151*4bdc9457SAndroid Build Coastguard Worker }
5152*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)5153*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
5154*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5155*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
5156*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5157*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
5158*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
5159*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5160*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
5161*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
5162*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5163*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_wasmsimd);
5164*4bdc9457SAndroid Build Coastguard Worker }
5165*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
5166*4bdc9457SAndroid Build Coastguard Worker
5167*4bdc9457SAndroid Build Coastguard Worker
5168*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_4)5169*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_4) {
5170*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5171*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5172*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5173*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5174*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5175*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5176*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5178*4bdc9457SAndroid Build Coastguard Worker }
5179*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_1_8_bw_1_8)5180*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_1_8_bw_1_8) {
5181*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
5182*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
5183*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5184*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5185*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5186*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5187*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5188*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5189*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5190*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5191*4bdc9457SAndroid Build Coastguard Worker }
5192*4bdc9457SAndroid Build Coastguard Worker }
5193*4bdc9457SAndroid Build Coastguard Worker }
5194*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_8)5195*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_8) {
5196*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5197*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5198*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5199*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5200*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5201*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5202*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5203*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5204*4bdc9457SAndroid Build Coastguard Worker }
5205*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_5_8)5206*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_5_8) {
5207*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5208*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5209*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5210*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5211*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5212*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5213*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5214*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5215*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5216*4bdc9457SAndroid Build Coastguard Worker }
5217*4bdc9457SAndroid Build Coastguard Worker }
5218*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_8_bw_5_8)5219*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_8_bw_5_8) {
5220*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5221*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5222*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5223*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5224*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5225*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5226*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5227*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5228*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5229*4bdc9457SAndroid Build Coastguard Worker }
5230*4bdc9457SAndroid Build Coastguard Worker }
5231*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_8_bw_4)5232*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_8_bw_4) {
5233*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5234*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5235*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5236*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5237*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5238*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5241*4bdc9457SAndroid Build Coastguard Worker }
5242*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_5_8_bw_4)5243*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_5_8_bw_4){
5244*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5245*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5246*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
5247*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5248*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
5249*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5250*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5251*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5252*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5253*4bdc9457SAndroid Build Coastguard Worker }
5254*4bdc9457SAndroid Build Coastguard Worker }
5255*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_5_8_bw_8)5256*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_5_8_bw_8){
5257*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5258*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5259*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5260*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5261*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5262*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5263*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5264*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5265*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5266*4bdc9457SAndroid Build Coastguard Worker }
5267*4bdc9457SAndroid Build Coastguard Worker }
5268*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_5_8_bw_5_8)5269*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_5_8_bw_5_8) {
5270*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5271*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
5272*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5273*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5274*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5275*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5276*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5277*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5278*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5279*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5280*4bdc9457SAndroid Build Coastguard Worker }
5281*4bdc9457SAndroid Build Coastguard Worker }
5282*4bdc9457SAndroid Build Coastguard Worker }
5283*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_4_is_8)5284*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_4_is_8) {
5285*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5286*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5287*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5288*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5289*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5290*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5291*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5292*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5293*4bdc9457SAndroid Build Coastguard Worker }
5294*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_4_os_8)5295*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_4_os_8) {
5296*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5297*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5298*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5299*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5300*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5301*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5302*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5303*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5304*4bdc9457SAndroid Build Coastguard Worker }
5305*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_4_bw_4_is_8_os_8)5306*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
5307*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5308*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5309*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5310*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5311*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5312*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5313*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5314*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5315*4bdc9457SAndroid Build Coastguard Worker }
5316*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_68_bw_76_ies_15)5317*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_68_bw_76_ies_15) {
5318*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5319*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
5320*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
5321*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
5322*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
5323*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5324*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
5325*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5326*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5327*4bdc9457SAndroid Build Coastguard Worker }
5328*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_12_bw_20_oes_15)5329*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_12_bw_20_oes_15) {
5330*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5331*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
5332*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
5333*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
5334*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
5335*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5336*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5337*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5338*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5339*4bdc9457SAndroid Build Coastguard Worker }
5340*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)5341*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
5342*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5343*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
5344*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5345*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
5346*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
5347*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5348*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
5349*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
5350*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5351*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_wasmsimd);
5352*4bdc9457SAndroid Build Coastguard Worker }
5353*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
5354*4bdc9457SAndroid Build Coastguard Worker
5355*4bdc9457SAndroid Build Coastguard Worker
5356*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_4)5357*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_4) {
5358*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5359*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5360*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5361*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5362*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5363*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5364*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5365*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5366*4bdc9457SAndroid Build Coastguard Worker }
5367*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_1_8_bw_1_8)5368*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_1_8_bw_1_8) {
5369*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
5370*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
5371*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5372*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5373*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5374*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5375*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5376*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5377*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5378*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5379*4bdc9457SAndroid Build Coastguard Worker }
5380*4bdc9457SAndroid Build Coastguard Worker }
5381*4bdc9457SAndroid Build Coastguard Worker }
5382*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_8)5383*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_8) {
5384*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5385*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5386*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5387*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5388*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5389*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5390*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5391*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5392*4bdc9457SAndroid Build Coastguard Worker }
5393*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_5_8)5394*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_5_8) {
5395*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5396*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5397*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5398*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5399*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5400*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5401*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5402*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5404*4bdc9457SAndroid Build Coastguard Worker }
5405*4bdc9457SAndroid Build Coastguard Worker }
5406*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_8_bw_5_8)5407*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_8_bw_5_8) {
5408*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5409*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5410*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5411*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5412*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5413*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5414*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5415*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5416*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5417*4bdc9457SAndroid Build Coastguard Worker }
5418*4bdc9457SAndroid Build Coastguard Worker }
5419*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_8_bw_4)5420*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_8_bw_4) {
5421*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5422*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5423*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5424*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5425*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5426*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5427*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5428*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5429*4bdc9457SAndroid Build Coastguard Worker }
5430*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_5_8_bw_4)5431*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_5_8_bw_4){
5432*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5433*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5434*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
5435*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5436*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
5437*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5438*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5439*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5441*4bdc9457SAndroid Build Coastguard Worker }
5442*4bdc9457SAndroid Build Coastguard Worker }
5443*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_5_8_bw_8)5444*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_5_8_bw_8){
5445*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5446*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5447*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5448*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5449*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5450*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5451*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5452*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5453*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5454*4bdc9457SAndroid Build Coastguard Worker }
5455*4bdc9457SAndroid Build Coastguard Worker }
5456*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_5_8_bw_5_8)5457*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_5_8_bw_5_8) {
5458*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5459*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
5460*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5461*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5462*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5463*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5464*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5465*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5466*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5467*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5468*4bdc9457SAndroid Build Coastguard Worker }
5469*4bdc9457SAndroid Build Coastguard Worker }
5470*4bdc9457SAndroid Build Coastguard Worker }
5471*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_4_is_8)5472*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_4_is_8) {
5473*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5474*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5475*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5476*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5477*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5478*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5479*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5480*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5481*4bdc9457SAndroid Build Coastguard Worker }
5482*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_4_os_8)5483*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_4_os_8) {
5484*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5485*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5486*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5487*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5488*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5489*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5490*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5491*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5492*4bdc9457SAndroid Build Coastguard Worker }
5493*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_4_bw_4_is_8_os_8)5494*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
5495*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5496*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5497*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5498*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5499*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5500*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5501*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5503*4bdc9457SAndroid Build Coastguard Worker }
5504*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_68_bw_76_ies_15)5505*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_68_bw_76_ies_15) {
5506*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5507*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
5508*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
5509*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
5510*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
5511*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5512*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
5513*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5514*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5515*4bdc9457SAndroid Build Coastguard Worker }
5516*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_12_bw_20_oes_15)5517*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_12_bw_20_oes_15) {
5518*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5519*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
5520*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
5521*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
5522*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
5523*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5524*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5525*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5526*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5527*4bdc9457SAndroid Build Coastguard Worker }
5528*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)5529*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
5530*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5531*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
5532*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5533*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
5534*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
5535*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5536*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
5537*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
5538*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5539*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_wasmsimd);
5540*4bdc9457SAndroid Build Coastguard Worker }
5541*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
5542*4bdc9457SAndroid Build Coastguard Worker
5543*4bdc9457SAndroid Build Coastguard Worker
5544*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_4)5545*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_4) {
5546*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5547*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5548*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5549*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5550*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5551*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5552*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5553*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5554*4bdc9457SAndroid Build Coastguard Worker }
5555*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_1_8_bw_1_8)5556*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_1_8_bw_1_8) {
5557*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
5558*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
5559*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5560*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5561*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5562*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5563*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5564*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5565*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5566*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5567*4bdc9457SAndroid Build Coastguard Worker }
5568*4bdc9457SAndroid Build Coastguard Worker }
5569*4bdc9457SAndroid Build Coastguard Worker }
5570*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_8)5571*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_8) {
5572*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5573*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5574*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5575*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5576*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5577*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5578*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5579*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5580*4bdc9457SAndroid Build Coastguard Worker }
5581*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_5_8)5582*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_5_8) {
5583*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5584*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5585*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5586*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5587*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5588*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5589*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5590*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5591*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5592*4bdc9457SAndroid Build Coastguard Worker }
5593*4bdc9457SAndroid Build Coastguard Worker }
5594*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_8_bw_5_8)5595*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_8_bw_5_8) {
5596*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5597*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5598*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5599*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5600*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5601*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5602*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5603*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5604*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5605*4bdc9457SAndroid Build Coastguard Worker }
5606*4bdc9457SAndroid Build Coastguard Worker }
5607*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_8_bw_4)5608*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_8_bw_4) {
5609*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5610*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5611*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5612*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5613*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5614*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5615*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5616*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5617*4bdc9457SAndroid Build Coastguard Worker }
5618*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_5_8_bw_4)5619*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_5_8_bw_4){
5620*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5621*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5622*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
5623*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5624*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
5625*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5626*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5627*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5628*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5629*4bdc9457SAndroid Build Coastguard Worker }
5630*4bdc9457SAndroid Build Coastguard Worker }
5631*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_5_8_bw_8)5632*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_5_8_bw_8){
5633*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5634*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5635*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5636*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5637*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5638*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5639*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5640*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5641*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5642*4bdc9457SAndroid Build Coastguard Worker }
5643*4bdc9457SAndroid Build Coastguard Worker }
5644*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_5_8_bw_5_8)5645*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_5_8_bw_5_8) {
5646*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5647*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
5648*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5649*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5650*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5651*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5652*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5653*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5654*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5655*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5656*4bdc9457SAndroid Build Coastguard Worker }
5657*4bdc9457SAndroid Build Coastguard Worker }
5658*4bdc9457SAndroid Build Coastguard Worker }
5659*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_4_is_8)5660*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_4_is_8) {
5661*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5662*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5663*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5664*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5665*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5666*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5667*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5668*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5669*4bdc9457SAndroid Build Coastguard Worker }
5670*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_4_os_8)5671*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_4_os_8) {
5672*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5673*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5674*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5675*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5676*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5677*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5678*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5679*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5680*4bdc9457SAndroid Build Coastguard Worker }
5681*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_4_bw_4_is_8_os_8)5682*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_4_bw_4_is_8_os_8) {
5683*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5684*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5685*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5686*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5687*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5688*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5689*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5690*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5691*4bdc9457SAndroid Build Coastguard Worker }
5692*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_68_bw_76_ies_15)5693*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_68_bw_76_ies_15) {
5694*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5695*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
5696*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
5697*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
5698*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
5699*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5700*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
5701*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5702*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5703*4bdc9457SAndroid Build Coastguard Worker }
5704*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_12_bw_20_oes_15)5705*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_12_bw_20_oes_15) {
5706*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5707*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
5708*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
5709*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
5710*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
5711*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5712*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5713*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5714*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5715*4bdc9457SAndroid Build Coastguard Worker }
5716*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4,bh_28_bw_92_ies_21_oes_17)5717*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_WASMSIMD_4, bh_28_bw_92_ies_21_oes_17) {
5718*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5719*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
5720*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5721*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
5722*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
5723*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5724*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
5725*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
5726*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_wasmsimd);
5728*4bdc9457SAndroid Build Coastguard Worker }
5729*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
5730*4bdc9457SAndroid Build Coastguard Worker
5731*4bdc9457SAndroid Build Coastguard Worker
5732*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_2)5733*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_2) {
5734*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5735*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5736*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5737*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5738*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5739*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5740*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5741*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5742*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5743*4bdc9457SAndroid Build Coastguard Worker }
5744*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_1_4_bw_1_4)5745*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_1_4_bw_1_4) {
5746*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5747*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
5748*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
5749*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5750*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5751*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5752*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5753*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5754*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5755*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5756*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5757*4bdc9457SAndroid Build Coastguard Worker }
5758*4bdc9457SAndroid Build Coastguard Worker }
5759*4bdc9457SAndroid Build Coastguard Worker }
5760*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_4)5761*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_4) {
5762*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5763*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5764*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5765*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
5766*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5767*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5768*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5769*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5770*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5771*4bdc9457SAndroid Build Coastguard Worker }
5772*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_3_4)5773*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_3_4) {
5774*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5775*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5776*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5777*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5778*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5779*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5780*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5781*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5782*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5783*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5784*4bdc9457SAndroid Build Coastguard Worker }
5785*4bdc9457SAndroid Build Coastguard Worker }
5786*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_4_bw_3_4)5787*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_4_bw_3_4) {
5788*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5789*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5790*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5791*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5792*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5793*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5794*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5795*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5796*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5797*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5798*4bdc9457SAndroid Build Coastguard Worker }
5799*4bdc9457SAndroid Build Coastguard Worker }
5800*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_4_bw_2)5801*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_4_bw_2) {
5802*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5803*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5804*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
5805*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
5806*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5807*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5808*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5809*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5810*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5811*4bdc9457SAndroid Build Coastguard Worker }
5812*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_3_4_bw_2)5813*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_3_4_bw_2){
5814*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5815*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5816*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5817*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
5818*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5819*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
5820*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5821*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5822*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5823*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5824*4bdc9457SAndroid Build Coastguard Worker }
5825*4bdc9457SAndroid Build Coastguard Worker }
5826*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_3_4_bw_4)5827*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_3_4_bw_4){
5828*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5829*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5830*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5831*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5832*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5833*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5834*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5835*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5836*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5838*4bdc9457SAndroid Build Coastguard Worker }
5839*4bdc9457SAndroid Build Coastguard Worker }
5840*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_3_4_bw_3_4)5841*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_3_4_bw_3_4) {
5842*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5843*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5844*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
5845*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5846*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5847*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5848*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5849*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5850*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5851*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5852*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5853*4bdc9457SAndroid Build Coastguard Worker }
5854*4bdc9457SAndroid Build Coastguard Worker }
5855*4bdc9457SAndroid Build Coastguard Worker }
5856*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_2_is_4)5857*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_2_is_4) {
5858*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5859*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5860*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5861*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
5862*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5863*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5864*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5865*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5866*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5867*4bdc9457SAndroid Build Coastguard Worker }
5868*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_2_os_4)5869*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_2_os_4) {
5870*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5871*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5872*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
5873*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5874*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5875*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5876*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5877*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5878*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5879*4bdc9457SAndroid Build Coastguard Worker }
5880*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)5881*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
5882*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5883*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5884*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5885*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5886*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5887*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5888*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5889*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5890*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5891*4bdc9457SAndroid Build Coastguard Worker }
5892*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_34_bw_38_ies_15)5893*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_34_bw_38_ies_15) {
5894*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5895*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5896*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
5897*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5898*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
5899*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
5900*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5901*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
5902*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5903*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5904*4bdc9457SAndroid Build Coastguard Worker }
5905*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_6_bw_10_oes_15)5906*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_6_bw_10_oes_15) {
5907*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5908*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5909*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
5910*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
5911*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
5912*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
5913*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5914*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5917*4bdc9457SAndroid Build Coastguard Worker }
5918*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)5919*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_DEC_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
5920*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5921*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5922*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
5923*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
5924*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
5925*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
5926*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5927*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
5928*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
5929*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5930*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_dec_zip_neon);
5931*4bdc9457SAndroid Build Coastguard Worker }
5932*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5933*4bdc9457SAndroid Build Coastguard Worker
5934*4bdc9457SAndroid Build Coastguard Worker
5935*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_2)5936*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_2) {
5937*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5938*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5939*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5940*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5941*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
5942*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5943*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5944*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5945*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
5946*4bdc9457SAndroid Build Coastguard Worker }
5947*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_1_4_bw_1_4)5948*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_1_4_bw_1_4) {
5949*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5950*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
5951*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
5952*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5953*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5954*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5955*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5956*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5957*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5958*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5959*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
5960*4bdc9457SAndroid Build Coastguard Worker }
5961*4bdc9457SAndroid Build Coastguard Worker }
5962*4bdc9457SAndroid Build Coastguard Worker }
5963*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_4)5964*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_4) {
5965*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5966*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5967*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5968*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
5969*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5970*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5971*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5972*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5973*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
5974*4bdc9457SAndroid Build Coastguard Worker }
5975*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_3_4)5976*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_3_4) {
5977*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5978*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5979*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5980*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5981*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5982*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5983*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
5984*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5985*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5986*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
5987*4bdc9457SAndroid Build Coastguard Worker }
5988*4bdc9457SAndroid Build Coastguard Worker }
5989*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_4_bw_3_4)5990*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_4_bw_3_4) {
5991*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5992*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
5993*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5994*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5995*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5996*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5997*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5998*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
5999*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6000*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6001*4bdc9457SAndroid Build Coastguard Worker }
6002*4bdc9457SAndroid Build Coastguard Worker }
6003*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_4_bw_2)6004*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_4_bw_2) {
6005*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6006*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6007*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6008*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
6009*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6010*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6011*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6012*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6013*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6014*4bdc9457SAndroid Build Coastguard Worker }
6015*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_3_4_bw_2)6016*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_3_4_bw_2){
6017*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6018*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6019*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6020*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
6021*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6022*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
6023*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6024*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6025*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6026*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6027*4bdc9457SAndroid Build Coastguard Worker }
6028*4bdc9457SAndroid Build Coastguard Worker }
6029*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_3_4_bw_4)6030*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_3_4_bw_4){
6031*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6032*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6033*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6034*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6035*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6036*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6037*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6038*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6039*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6041*4bdc9457SAndroid Build Coastguard Worker }
6042*4bdc9457SAndroid Build Coastguard Worker }
6043*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_3_4_bw_3_4)6044*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_3_4_bw_3_4) {
6045*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6046*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6047*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
6048*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6049*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6050*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6051*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6052*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6053*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6054*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6055*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6056*4bdc9457SAndroid Build Coastguard Worker }
6057*4bdc9457SAndroid Build Coastguard Worker }
6058*4bdc9457SAndroid Build Coastguard Worker }
6059*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_2_is_4)6060*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_2_is_4) {
6061*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6062*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6063*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6064*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6065*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6066*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6067*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6068*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6069*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6070*4bdc9457SAndroid Build Coastguard Worker }
6071*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_2_os_4)6072*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_2_os_4) {
6073*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6074*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6075*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6076*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6077*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6078*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6079*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6080*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6081*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6082*4bdc9457SAndroid Build Coastguard Worker }
6083*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)6084*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
6085*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6086*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6087*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6088*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6089*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6090*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6091*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6092*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6093*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6094*4bdc9457SAndroid Build Coastguard Worker }
6095*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_34_bw_38_ies_15)6096*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_34_bw_38_ies_15) {
6097*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6098*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6099*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
6100*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
6101*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
6102*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
6103*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6104*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
6105*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6106*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6107*4bdc9457SAndroid Build Coastguard Worker }
6108*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_6_bw_10_oes_15)6109*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_6_bw_10_oes_15) {
6110*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6111*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6112*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
6113*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
6114*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
6115*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
6116*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6117*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6118*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6119*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6120*4bdc9457SAndroid Build Coastguard Worker }
6121*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)6122*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MOV_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
6123*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6124*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6125*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
6126*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
6127*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
6128*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
6129*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6130*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
6131*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
6132*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6133*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_mov_zip_neon);
6134*4bdc9457SAndroid Build Coastguard Worker }
6135*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6136*4bdc9457SAndroid Build Coastguard Worker
6137*4bdc9457SAndroid Build Coastguard Worker
6138*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_2)6139*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_2) {
6140*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6141*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6142*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6143*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6144*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6145*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6146*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6147*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6148*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6149*4bdc9457SAndroid Build Coastguard Worker }
6150*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_1_4_bw_1_4)6151*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_1_4_bw_1_4) {
6152*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6153*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
6154*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
6155*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6156*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6157*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6158*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6159*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6160*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6161*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6162*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6163*4bdc9457SAndroid Build Coastguard Worker }
6164*4bdc9457SAndroid Build Coastguard Worker }
6165*4bdc9457SAndroid Build Coastguard Worker }
6166*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_4)6167*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_4) {
6168*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6169*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6170*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6171*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6172*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6173*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6174*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6175*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6176*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6177*4bdc9457SAndroid Build Coastguard Worker }
6178*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_3_4)6179*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_3_4) {
6180*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6181*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6182*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6183*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6184*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6185*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6186*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6187*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6190*4bdc9457SAndroid Build Coastguard Worker }
6191*4bdc9457SAndroid Build Coastguard Worker }
6192*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_3_4)6193*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_3_4) {
6194*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6195*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6196*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6197*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6198*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6199*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6200*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6201*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6202*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6203*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6204*4bdc9457SAndroid Build Coastguard Worker }
6205*4bdc9457SAndroid Build Coastguard Worker }
6206*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_2)6207*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_2) {
6208*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6209*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6210*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6211*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
6212*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6213*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6214*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6215*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6216*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6217*4bdc9457SAndroid Build Coastguard Worker }
6218*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_3_4_bw_2)6219*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_3_4_bw_2){
6220*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6221*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6222*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6223*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
6224*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6225*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
6226*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6227*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6228*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6229*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6230*4bdc9457SAndroid Build Coastguard Worker }
6231*4bdc9457SAndroid Build Coastguard Worker }
6232*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_3_4_bw_4)6233*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_3_4_bw_4){
6234*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6235*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6236*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6237*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6238*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6239*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6240*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6241*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6242*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6243*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6244*4bdc9457SAndroid Build Coastguard Worker }
6245*4bdc9457SAndroid Build Coastguard Worker }
6246*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_3_4_bw_3_4)6247*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_3_4_bw_3_4) {
6248*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6249*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6250*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
6251*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6252*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6253*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6254*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6255*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6256*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6257*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6258*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6259*4bdc9457SAndroid Build Coastguard Worker }
6260*4bdc9457SAndroid Build Coastguard Worker }
6261*4bdc9457SAndroid Build Coastguard Worker }
6262*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_2_is_4)6263*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_2_is_4) {
6264*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6265*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6266*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6267*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6268*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6269*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6270*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6271*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6272*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6273*4bdc9457SAndroid Build Coastguard Worker }
6274*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_2_os_4)6275*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_2_os_4) {
6276*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6277*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6278*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6279*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6280*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6281*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6282*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6283*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6284*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6285*4bdc9457SAndroid Build Coastguard Worker }
6286*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)6287*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
6288*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6289*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6290*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6291*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6292*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6293*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6294*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6295*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6296*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6297*4bdc9457SAndroid Build Coastguard Worker }
6298*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_34_bw_38_ies_15)6299*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_34_bw_38_ies_15) {
6300*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6301*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6302*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
6303*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
6304*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
6305*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
6306*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6307*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
6308*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6309*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6310*4bdc9457SAndroid Build Coastguard Worker }
6311*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_6_bw_10_oes_15)6312*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_6_bw_10_oes_15) {
6313*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6314*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6315*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
6316*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
6317*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
6318*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
6319*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6320*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6321*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6322*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6323*4bdc9457SAndroid Build Coastguard Worker }
6324*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)6325*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_MULTI_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
6326*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6327*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6328*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
6329*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
6330*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
6331*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
6332*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6333*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
6334*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
6335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_multi_zip_neon);
6337*4bdc9457SAndroid Build Coastguard Worker }
6338*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6339*4bdc9457SAndroid Build Coastguard Worker
6340*4bdc9457SAndroid Build Coastguard Worker
6341*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_2)6342*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_2) {
6343*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6344*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6345*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6346*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6347*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6348*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6349*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6350*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6351*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6352*4bdc9457SAndroid Build Coastguard Worker }
6353*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_1_4_bw_1_4)6354*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_1_4_bw_1_4) {
6355*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6356*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
6357*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
6358*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6359*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6360*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6361*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6362*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6363*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6364*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6365*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6366*4bdc9457SAndroid Build Coastguard Worker }
6367*4bdc9457SAndroid Build Coastguard Worker }
6368*4bdc9457SAndroid Build Coastguard Worker }
6369*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_4)6370*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_4) {
6371*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6372*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6373*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6374*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6375*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6376*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6377*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6378*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6379*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6380*4bdc9457SAndroid Build Coastguard Worker }
6381*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_3_4)6382*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_3_4) {
6383*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6384*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6385*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6386*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6387*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6388*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6389*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6390*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6391*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6392*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6393*4bdc9457SAndroid Build Coastguard Worker }
6394*4bdc9457SAndroid Build Coastguard Worker }
6395*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_3_4)6396*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_3_4) {
6397*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6398*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6399*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6400*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6401*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6402*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6403*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6404*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6405*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6406*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6407*4bdc9457SAndroid Build Coastguard Worker }
6408*4bdc9457SAndroid Build Coastguard Worker }
6409*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_2)6410*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_2) {
6411*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6412*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6413*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6414*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
6415*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6416*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6417*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6418*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6419*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6420*4bdc9457SAndroid Build Coastguard Worker }
6421*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_3_4_bw_2)6422*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_3_4_bw_2){
6423*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6424*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6425*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6426*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
6427*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6428*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
6429*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6430*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6431*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6432*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6433*4bdc9457SAndroid Build Coastguard Worker }
6434*4bdc9457SAndroid Build Coastguard Worker }
6435*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_3_4_bw_4)6436*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_3_4_bw_4){
6437*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6438*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6439*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6440*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6441*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6442*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6443*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6444*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6445*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6446*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6447*4bdc9457SAndroid Build Coastguard Worker }
6448*4bdc9457SAndroid Build Coastguard Worker }
6449*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_3_4_bw_3_4)6450*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_3_4_bw_3_4) {
6451*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6452*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6453*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
6454*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6455*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6456*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6457*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6458*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6459*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6460*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6461*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6462*4bdc9457SAndroid Build Coastguard Worker }
6463*4bdc9457SAndroid Build Coastguard Worker }
6464*4bdc9457SAndroid Build Coastguard Worker }
6465*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_2_is_4)6466*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_2_is_4) {
6467*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6468*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6469*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6470*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6471*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6472*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6473*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6474*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6475*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6476*4bdc9457SAndroid Build Coastguard Worker }
6477*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_2_os_4)6478*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_2_os_4) {
6479*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6480*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6481*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6482*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6483*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6484*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6485*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6486*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6487*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6488*4bdc9457SAndroid Build Coastguard Worker }
6489*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)6490*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
6491*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6492*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6493*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6494*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6495*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6496*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6497*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6498*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6499*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6500*4bdc9457SAndroid Build Coastguard Worker }
6501*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_34_bw_38_ies_15)6502*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_34_bw_38_ies_15) {
6503*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6504*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6505*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
6506*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
6507*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
6508*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
6509*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6510*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
6511*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6512*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6513*4bdc9457SAndroid Build Coastguard Worker }
6514*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_6_bw_10_oes_15)6515*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_6_bw_10_oes_15) {
6516*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6517*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6518*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
6519*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
6520*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
6521*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
6522*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6523*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6524*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6525*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6526*4bdc9457SAndroid Build Coastguard Worker }
6527*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)6528*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_MULTI_SWITCH_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
6529*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6530*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6531*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
6532*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
6533*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
6534*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
6535*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6536*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
6537*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
6538*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6539*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_multi_switch_zip_neon);
6540*4bdc9457SAndroid Build Coastguard Worker }
6541*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6542*4bdc9457SAndroid Build Coastguard Worker
6543*4bdc9457SAndroid Build Coastguard Worker
6544*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_2)6545*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_2) {
6546*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6547*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6548*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6549*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6550*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6551*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6552*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6553*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6554*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6555*4bdc9457SAndroid Build Coastguard Worker }
6556*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_1_4_bw_1_4)6557*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_1_4_bw_1_4) {
6558*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6559*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
6560*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
6561*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6562*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6563*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6564*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6565*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6566*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6567*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6568*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6569*4bdc9457SAndroid Build Coastguard Worker }
6570*4bdc9457SAndroid Build Coastguard Worker }
6571*4bdc9457SAndroid Build Coastguard Worker }
6572*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_4)6573*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_4) {
6574*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6575*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6576*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6577*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6578*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6579*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6580*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6581*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6582*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6583*4bdc9457SAndroid Build Coastguard Worker }
6584*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_3_4)6585*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_3_4) {
6586*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6587*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6588*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6589*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6590*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6591*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6592*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6593*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6594*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6595*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6596*4bdc9457SAndroid Build Coastguard Worker }
6597*4bdc9457SAndroid Build Coastguard Worker }
6598*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_4_bw_3_4)6599*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_4_bw_3_4) {
6600*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6601*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6602*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6603*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6604*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6605*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6606*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6607*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6608*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6609*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6610*4bdc9457SAndroid Build Coastguard Worker }
6611*4bdc9457SAndroid Build Coastguard Worker }
6612*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_4_bw_2)6613*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_4_bw_2) {
6614*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6615*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6616*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6617*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
6618*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6619*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6620*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6621*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6622*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6623*4bdc9457SAndroid Build Coastguard Worker }
6624*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_3_4_bw_2)6625*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_3_4_bw_2){
6626*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6627*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6628*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6629*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
6630*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6631*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
6632*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6633*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6634*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6635*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6636*4bdc9457SAndroid Build Coastguard Worker }
6637*4bdc9457SAndroid Build Coastguard Worker }
6638*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_3_4_bw_4)6639*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_3_4_bw_4){
6640*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6641*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6642*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6643*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6644*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6645*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6646*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6647*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6648*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6649*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6650*4bdc9457SAndroid Build Coastguard Worker }
6651*4bdc9457SAndroid Build Coastguard Worker }
6652*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_3_4_bw_3_4)6653*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_3_4_bw_3_4) {
6654*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6655*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6656*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
6657*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6658*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6659*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6660*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6661*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6662*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6663*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6664*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6665*4bdc9457SAndroid Build Coastguard Worker }
6666*4bdc9457SAndroid Build Coastguard Worker }
6667*4bdc9457SAndroid Build Coastguard Worker }
6668*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_2_is_4)6669*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_2_is_4) {
6670*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6671*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6672*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6673*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6674*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6675*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6676*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6677*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6678*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6679*4bdc9457SAndroid Build Coastguard Worker }
6680*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_2_os_4)6681*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_2_os_4) {
6682*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6683*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6684*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6685*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6686*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6687*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6688*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6689*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6690*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6691*4bdc9457SAndroid Build Coastguard Worker }
6692*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)6693*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
6694*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6695*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6696*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6697*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6698*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6699*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6700*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6701*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6702*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6703*4bdc9457SAndroid Build Coastguard Worker }
6704*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_34_bw_38_ies_15)6705*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_34_bw_38_ies_15) {
6706*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6707*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6708*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
6709*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
6710*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
6711*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
6712*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6713*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
6714*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6715*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6716*4bdc9457SAndroid Build Coastguard Worker }
6717*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_6_bw_10_oes_15)6718*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_6_bw_10_oes_15) {
6719*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6720*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6721*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
6722*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
6723*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
6724*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
6725*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6726*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6727*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6729*4bdc9457SAndroid Build Coastguard Worker }
6730*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)6731*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_DEC_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
6732*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6733*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6734*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
6735*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
6736*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
6737*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
6738*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6739*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
6740*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
6741*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6742*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_dec_zip_neon);
6743*4bdc9457SAndroid Build Coastguard Worker }
6744*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6745*4bdc9457SAndroid Build Coastguard Worker
6746*4bdc9457SAndroid Build Coastguard Worker
6747*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_2)6748*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_2) {
6749*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6750*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6751*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6752*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6753*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6754*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6755*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6756*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6758*4bdc9457SAndroid Build Coastguard Worker }
6759*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_1_4_bw_1_4)6760*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_1_4_bw_1_4) {
6761*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6762*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
6763*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
6764*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6765*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6766*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6767*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6768*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6769*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6770*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6771*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6772*4bdc9457SAndroid Build Coastguard Worker }
6773*4bdc9457SAndroid Build Coastguard Worker }
6774*4bdc9457SAndroid Build Coastguard Worker }
6775*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_4)6776*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_4) {
6777*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6778*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6779*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6780*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6781*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6782*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6783*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6784*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6785*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6786*4bdc9457SAndroid Build Coastguard Worker }
6787*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_3_4)6788*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_3_4) {
6789*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6790*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6791*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6792*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6793*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6794*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6795*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6796*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6797*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6798*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6799*4bdc9457SAndroid Build Coastguard Worker }
6800*4bdc9457SAndroid Build Coastguard Worker }
6801*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_4_bw_3_4)6802*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_4_bw_3_4) {
6803*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6804*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6805*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6806*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6807*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6808*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6809*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6810*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6811*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6812*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6813*4bdc9457SAndroid Build Coastguard Worker }
6814*4bdc9457SAndroid Build Coastguard Worker }
6815*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_4_bw_2)6816*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_4_bw_2) {
6817*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6818*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6819*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6820*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
6821*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6822*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
6823*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6824*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6825*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6826*4bdc9457SAndroid Build Coastguard Worker }
6827*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_3_4_bw_2)6828*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_3_4_bw_2){
6829*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6830*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6831*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6832*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
6833*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6834*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
6835*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6836*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6837*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6838*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6839*4bdc9457SAndroid Build Coastguard Worker }
6840*4bdc9457SAndroid Build Coastguard Worker }
6841*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_3_4_bw_4)6842*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_3_4_bw_4){
6843*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6844*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6845*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6846*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6847*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6848*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6849*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6850*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6851*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6852*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6853*4bdc9457SAndroid Build Coastguard Worker }
6854*4bdc9457SAndroid Build Coastguard Worker }
6855*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_3_4_bw_3_4)6856*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_3_4_bw_3_4) {
6857*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6858*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6859*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
6860*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6861*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6862*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6863*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6864*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6865*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6866*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6867*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6868*4bdc9457SAndroid Build Coastguard Worker }
6869*4bdc9457SAndroid Build Coastguard Worker }
6870*4bdc9457SAndroid Build Coastguard Worker }
6871*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_2_is_4)6872*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_2_is_4) {
6873*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6874*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6875*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6876*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6877*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6878*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6879*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6880*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6881*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6882*4bdc9457SAndroid Build Coastguard Worker }
6883*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_2_os_4)6884*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_2_os_4) {
6885*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6886*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6887*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
6888*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6889*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6890*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6891*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6892*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6893*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6894*4bdc9457SAndroid Build Coastguard Worker }
6895*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)6896*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
6897*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6898*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6899*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6900*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6901*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6902*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6903*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6904*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6905*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6906*4bdc9457SAndroid Build Coastguard Worker }
6907*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_34_bw_38_ies_15)6908*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_34_bw_38_ies_15) {
6909*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6910*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6911*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
6912*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
6913*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
6914*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
6915*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6916*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
6917*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6918*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6919*4bdc9457SAndroid Build Coastguard Worker }
6920*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_6_bw_10_oes_15)6921*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_6_bw_10_oes_15) {
6922*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6923*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6924*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
6925*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
6926*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
6927*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
6928*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6929*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6930*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6931*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6932*4bdc9457SAndroid Build Coastguard Worker }
6933*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)6934*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MOV_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
6935*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6936*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6937*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
6938*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
6939*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
6940*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
6941*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6942*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
6943*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
6944*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6945*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_mov_zip_neon);
6946*4bdc9457SAndroid Build Coastguard Worker }
6947*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6948*4bdc9457SAndroid Build Coastguard Worker
6949*4bdc9457SAndroid Build Coastguard Worker
6950*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_2)6951*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_2) {
6952*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6953*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6954*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6955*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6956*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
6957*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6958*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6959*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6960*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
6961*4bdc9457SAndroid Build Coastguard Worker }
6962*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_1_4_bw_1_4)6963*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_1_4_bw_1_4) {
6964*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6965*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
6966*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
6967*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6968*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6969*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6970*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6971*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6972*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6973*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6974*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
6975*4bdc9457SAndroid Build Coastguard Worker }
6976*4bdc9457SAndroid Build Coastguard Worker }
6977*4bdc9457SAndroid Build Coastguard Worker }
6978*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_4)6979*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_4) {
6980*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6981*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6982*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
6983*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
6984*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
6985*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6986*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
6987*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6988*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
6989*4bdc9457SAndroid Build Coastguard Worker }
6990*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_3_4)6991*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_3_4) {
6992*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6993*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
6994*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6995*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6996*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
6997*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6998*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
6999*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7000*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7001*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7002*4bdc9457SAndroid Build Coastguard Worker }
7003*4bdc9457SAndroid Build Coastguard Worker }
7004*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_3_4)7005*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_3_4) {
7006*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7007*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7008*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7009*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7010*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7011*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7012*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7013*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7014*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7015*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7016*4bdc9457SAndroid Build Coastguard Worker }
7017*4bdc9457SAndroid Build Coastguard Worker }
7018*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_2)7019*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_2) {
7020*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7021*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7022*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
7023*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
7024*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7025*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7026*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7027*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7029*4bdc9457SAndroid Build Coastguard Worker }
7030*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_3_4_bw_2)7031*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_3_4_bw_2){
7032*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7033*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7034*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7035*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
7036*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7037*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
7038*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7039*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7040*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7042*4bdc9457SAndroid Build Coastguard Worker }
7043*4bdc9457SAndroid Build Coastguard Worker }
7044*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_3_4_bw_4)7045*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_3_4_bw_4){
7046*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7047*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7048*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7049*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7050*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7051*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7052*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7053*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7054*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7055*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7056*4bdc9457SAndroid Build Coastguard Worker }
7057*4bdc9457SAndroid Build Coastguard Worker }
7058*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_3_4_bw_3_4)7059*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_3_4_bw_3_4) {
7060*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7061*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7062*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
7063*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7064*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
7065*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7066*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7067*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7068*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7069*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7070*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7071*4bdc9457SAndroid Build Coastguard Worker }
7072*4bdc9457SAndroid Build Coastguard Worker }
7073*4bdc9457SAndroid Build Coastguard Worker }
7074*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_2_is_4)7075*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_2_is_4) {
7076*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7077*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7078*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7079*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
7080*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7081*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7082*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7083*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7084*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7085*4bdc9457SAndroid Build Coastguard Worker }
7086*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_2_os_4)7087*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_2_os_4) {
7088*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7089*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7090*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
7091*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7092*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7093*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7094*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7095*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7096*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7097*4bdc9457SAndroid Build Coastguard Worker }
7098*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)7099*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
7100*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7101*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7102*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7103*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7104*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7105*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7106*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7107*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7108*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7109*4bdc9457SAndroid Build Coastguard Worker }
7110*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_34_bw_38_ies_15)7111*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_34_bw_38_ies_15) {
7112*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7113*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7114*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
7115*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
7116*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
7117*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
7118*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7119*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
7120*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7121*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7122*4bdc9457SAndroid Build Coastguard Worker }
7123*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_6_bw_10_oes_15)7124*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_6_bw_10_oes_15) {
7125*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7126*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7127*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
7128*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
7129*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
7130*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
7131*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7132*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
7133*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7134*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7135*4bdc9457SAndroid Build Coastguard Worker }
7136*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)7137*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_MULTI_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
7138*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7139*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7140*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
7141*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
7142*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
7143*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
7144*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7145*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
7146*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
7147*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7148*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_multi_zip_neon);
7149*4bdc9457SAndroid Build Coastguard Worker }
7150*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
7151*4bdc9457SAndroid Build Coastguard Worker
7152*4bdc9457SAndroid Build Coastguard Worker
7153*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_2)7154*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_2) {
7155*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7156*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7157*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7158*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7159*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7160*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7161*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7162*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7163*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7164*4bdc9457SAndroid Build Coastguard Worker }
7165*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_1_4_bw_1_4)7166*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_1_4_bw_1_4) {
7167*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7168*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
7169*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++j){
7170*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7171*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
7172*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
7173*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7174*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7175*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7176*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7178*4bdc9457SAndroid Build Coastguard Worker }
7179*4bdc9457SAndroid Build Coastguard Worker }
7180*4bdc9457SAndroid Build Coastguard Worker }
7181*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_4)7182*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_4) {
7183*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7184*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7185*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7186*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
7187*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7188*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7189*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7190*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7191*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7192*4bdc9457SAndroid Build Coastguard Worker }
7193*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_3_4)7194*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_3_4) {
7195*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7196*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7197*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7198*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7199*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7200*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7201*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7202*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7203*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7204*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7205*4bdc9457SAndroid Build Coastguard Worker }
7206*4bdc9457SAndroid Build Coastguard Worker }
7207*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_3_4)7208*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_3_4) {
7209*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7210*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7211*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7212*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7213*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7214*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7215*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7216*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7217*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7218*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7219*4bdc9457SAndroid Build Coastguard Worker }
7220*4bdc9457SAndroid Build Coastguard Worker }
7221*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_2)7222*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_2) {
7223*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7224*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7225*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
7226*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
7227*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7228*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7229*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7230*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7231*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7232*4bdc9457SAndroid Build Coastguard Worker }
7233*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_3_4_bw_2)7234*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_3_4_bw_2){
7235*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7236*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7237*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7238*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
7239*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7240*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
7241*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7242*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7243*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7244*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7245*4bdc9457SAndroid Build Coastguard Worker }
7246*4bdc9457SAndroid Build Coastguard Worker }
7247*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_3_4_bw_4)7248*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_3_4_bw_4){
7249*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7250*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7251*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7252*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7253*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7254*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7255*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7256*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7257*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7258*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7259*4bdc9457SAndroid Build Coastguard Worker }
7260*4bdc9457SAndroid Build Coastguard Worker }
7261*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_3_4_bw_3_4)7262*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_3_4_bw_3_4) {
7263*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7264*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
7265*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++j){
7266*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7267*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
7268*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7269*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7270*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7271*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7272*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7273*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7274*4bdc9457SAndroid Build Coastguard Worker }
7275*4bdc9457SAndroid Build Coastguard Worker }
7276*4bdc9457SAndroid Build Coastguard Worker }
7277*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_2_is_4)7278*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_2_is_4) {
7279*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7280*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7281*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7282*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
7283*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7284*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7285*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7286*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7287*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7288*4bdc9457SAndroid Build Coastguard Worker }
7289*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_2_os_4)7290*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_2_os_4) {
7291*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7292*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7293*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
7294*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7295*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7296*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7297*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7298*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7300*4bdc9457SAndroid Build Coastguard Worker }
7301*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_2_bw_2_is_4_os_4)7302*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_2_bw_2_is_4_os_4) {
7303*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7304*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7305*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7306*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7307*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
7308*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
7309*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7310*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7311*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7312*4bdc9457SAndroid Build Coastguard Worker }
7313*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_34_bw_38_ies_15)7314*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_34_bw_38_ies_15) {
7315*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7316*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7317*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
7318*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
7319*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
7320*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
7321*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7322*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
7323*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7324*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7325*4bdc9457SAndroid Build Coastguard Worker }
7326*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_6_bw_10_oes_15)7327*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_6_bw_10_oes_15) {
7328*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7329*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7330*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
7331*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
7332*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
7333*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
7334*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7335*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
7336*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7337*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7338*4bdc9457SAndroid Build Coastguard Worker }
7339*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4,bh_14_bw_46_ies_21_oes_17)7340*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__2X2_REUSE_SWITCH_ZIP_NEON_4, bh_14_bw_46_ies_21_oes_17) {
7341*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7342*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7343*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
7344*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
7345*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
7346*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
7347*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7348*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
7349*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
7350*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7351*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__2x2_reuse_switch_zip_neon);
7352*4bdc9457SAndroid Build Coastguard Worker }
7353*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
7354*4bdc9457SAndroid Build Coastguard Worker
7355*4bdc9457SAndroid Build Coastguard Worker
7356*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_4)7357*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_4) {
7358*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7359*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7360*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7361*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7362*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7363*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7364*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7365*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7366*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7367*4bdc9457SAndroid Build Coastguard Worker }
7368*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_1_8_bw_1_8)7369*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_1_8_bw_1_8) {
7370*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7371*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
7372*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
7373*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7374*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
7375*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
7376*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7377*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7378*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7379*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7380*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7381*4bdc9457SAndroid Build Coastguard Worker }
7382*4bdc9457SAndroid Build Coastguard Worker }
7383*4bdc9457SAndroid Build Coastguard Worker }
7384*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_8)7385*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_8) {
7386*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7387*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7388*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7389*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7390*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7391*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7392*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7393*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7394*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7395*4bdc9457SAndroid Build Coastguard Worker }
7396*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_5_8)7397*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_5_8) {
7398*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7399*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7400*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7401*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7402*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7403*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7404*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7405*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7406*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7407*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7408*4bdc9457SAndroid Build Coastguard Worker }
7409*4bdc9457SAndroid Build Coastguard Worker }
7410*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_8_bw_5_8)7411*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_8_bw_5_8) {
7412*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7413*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7414*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7415*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7416*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7417*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7418*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7419*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7420*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7421*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7422*4bdc9457SAndroid Build Coastguard Worker }
7423*4bdc9457SAndroid Build Coastguard Worker }
7424*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_8_bw_4)7425*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_8_bw_4) {
7426*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7427*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7428*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7429*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
7430*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7431*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7432*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7433*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7434*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7435*4bdc9457SAndroid Build Coastguard Worker }
7436*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_5_8_bw_4)7437*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_5_8_bw_4){
7438*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7439*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7440*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7441*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
7442*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7443*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
7444*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7445*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7446*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7447*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7448*4bdc9457SAndroid Build Coastguard Worker }
7449*4bdc9457SAndroid Build Coastguard Worker }
7450*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_5_8_bw_8)7451*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_5_8_bw_8){
7452*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7453*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7454*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7455*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7456*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7457*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7458*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7459*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7460*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7461*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7462*4bdc9457SAndroid Build Coastguard Worker }
7463*4bdc9457SAndroid Build Coastguard Worker }
7464*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_5_8_bw_5_8)7465*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_5_8_bw_5_8) {
7466*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7467*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7468*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
7469*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7470*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
7471*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7472*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7473*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7474*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7475*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7476*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7477*4bdc9457SAndroid Build Coastguard Worker }
7478*4bdc9457SAndroid Build Coastguard Worker }
7479*4bdc9457SAndroid Build Coastguard Worker }
7480*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_4_is_8)7481*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_4_is_8) {
7482*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7483*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7484*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7485*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7486*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7487*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7488*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7489*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7490*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7491*4bdc9457SAndroid Build Coastguard Worker }
7492*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_4_os_8)7493*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_4_os_8) {
7494*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7495*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7496*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7497*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7498*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7499*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7500*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7501*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7503*4bdc9457SAndroid Build Coastguard Worker }
7504*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)7505*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
7506*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7507*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7508*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7509*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7510*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7511*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7512*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7513*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7514*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7515*4bdc9457SAndroid Build Coastguard Worker }
7516*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_68_bw_76_ies_15)7517*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_68_bw_76_ies_15) {
7518*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7519*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7520*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
7521*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
7522*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
7523*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
7524*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7525*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
7526*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7527*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7528*4bdc9457SAndroid Build Coastguard Worker }
7529*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_12_bw_20_oes_15)7530*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_12_bw_20_oes_15) {
7531*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7532*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7533*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
7534*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
7535*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
7536*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
7537*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7538*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
7539*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7540*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7541*4bdc9457SAndroid Build Coastguard Worker }
7542*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)7543*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
7544*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7545*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7546*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
7547*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
7548*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
7549*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
7550*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7551*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
7552*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
7553*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7554*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_dec_zip_neon);
7555*4bdc9457SAndroid Build Coastguard Worker }
7556*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
7557*4bdc9457SAndroid Build Coastguard Worker
7558*4bdc9457SAndroid Build Coastguard Worker
7559*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_4)7560*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_4) {
7561*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7562*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7563*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7564*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7565*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7566*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7567*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7568*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7569*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7570*4bdc9457SAndroid Build Coastguard Worker }
7571*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_1_8_bw_1_8)7572*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_1_8_bw_1_8) {
7573*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7574*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
7575*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
7576*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7577*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
7578*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
7579*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7580*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7581*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7582*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7583*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7584*4bdc9457SAndroid Build Coastguard Worker }
7585*4bdc9457SAndroid Build Coastguard Worker }
7586*4bdc9457SAndroid Build Coastguard Worker }
7587*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_8)7588*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_8) {
7589*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7590*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7591*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7592*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7593*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7594*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7595*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7596*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7597*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7598*4bdc9457SAndroid Build Coastguard Worker }
7599*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_5_8)7600*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_5_8) {
7601*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7602*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7603*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7604*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7605*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7606*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7607*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7608*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7609*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7610*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7611*4bdc9457SAndroid Build Coastguard Worker }
7612*4bdc9457SAndroid Build Coastguard Worker }
7613*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_8_bw_5_8)7614*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_8_bw_5_8) {
7615*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7616*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7617*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7618*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7619*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7620*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7621*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7622*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7623*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7624*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7625*4bdc9457SAndroid Build Coastguard Worker }
7626*4bdc9457SAndroid Build Coastguard Worker }
7627*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_8_bw_4)7628*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_8_bw_4) {
7629*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7630*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7631*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7632*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
7633*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7634*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7635*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7636*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7637*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7638*4bdc9457SAndroid Build Coastguard Worker }
7639*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_5_8_bw_4)7640*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_5_8_bw_4){
7641*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7642*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7643*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7644*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
7645*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7646*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
7647*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7648*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7649*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7650*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7651*4bdc9457SAndroid Build Coastguard Worker }
7652*4bdc9457SAndroid Build Coastguard Worker }
7653*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_5_8_bw_8)7654*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_5_8_bw_8){
7655*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7656*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7657*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7658*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7659*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7660*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7661*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7662*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7663*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7664*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7665*4bdc9457SAndroid Build Coastguard Worker }
7666*4bdc9457SAndroid Build Coastguard Worker }
7667*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_5_8_bw_5_8)7668*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_5_8_bw_5_8) {
7669*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7670*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7671*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
7672*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7673*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
7674*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7675*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7676*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7677*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7678*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7679*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7680*4bdc9457SAndroid Build Coastguard Worker }
7681*4bdc9457SAndroid Build Coastguard Worker }
7682*4bdc9457SAndroid Build Coastguard Worker }
7683*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_4_is_8)7684*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_4_is_8) {
7685*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7686*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7687*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7688*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7689*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7690*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7691*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7692*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7693*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7694*4bdc9457SAndroid Build Coastguard Worker }
7695*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_4_os_8)7696*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_4_os_8) {
7697*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7698*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7699*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7700*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7701*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7702*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7703*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7704*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7705*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7706*4bdc9457SAndroid Build Coastguard Worker }
7707*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)7708*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
7709*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7710*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7711*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7712*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7713*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7714*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7715*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7716*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7717*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7718*4bdc9457SAndroid Build Coastguard Worker }
7719*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_68_bw_76_ies_15)7720*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_68_bw_76_ies_15) {
7721*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7722*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7723*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
7724*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
7725*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
7726*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
7727*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7728*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
7729*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7730*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7731*4bdc9457SAndroid Build Coastguard Worker }
7732*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_12_bw_20_oes_15)7733*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_12_bw_20_oes_15) {
7734*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7735*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7736*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
7737*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
7738*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
7739*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
7740*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7741*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
7742*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7743*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7744*4bdc9457SAndroid Build Coastguard Worker }
7745*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)7746*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
7747*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7748*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7749*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
7750*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
7751*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
7752*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
7753*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7754*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
7755*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
7756*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_mov_zip_neon);
7758*4bdc9457SAndroid Build Coastguard Worker }
7759*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
7760*4bdc9457SAndroid Build Coastguard Worker
7761*4bdc9457SAndroid Build Coastguard Worker
7762*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_4)7763*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_4) {
7764*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7765*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7766*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7767*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7768*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7769*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7770*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7771*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7772*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7773*4bdc9457SAndroid Build Coastguard Worker }
7774*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_1_8_bw_1_8)7775*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_1_8_bw_1_8) {
7776*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7777*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
7778*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
7779*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7780*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
7781*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
7782*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7783*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7784*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7785*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7786*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7787*4bdc9457SAndroid Build Coastguard Worker }
7788*4bdc9457SAndroid Build Coastguard Worker }
7789*4bdc9457SAndroid Build Coastguard Worker }
7790*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_8)7791*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_8) {
7792*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7793*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7794*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7795*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7796*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7797*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7798*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7799*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7800*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7801*4bdc9457SAndroid Build Coastguard Worker }
7802*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_5_8)7803*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_5_8) {
7804*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7805*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7806*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7807*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7808*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7809*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7810*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7811*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7812*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7813*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7814*4bdc9457SAndroid Build Coastguard Worker }
7815*4bdc9457SAndroid Build Coastguard Worker }
7816*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_8_bw_5_8)7817*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_8_bw_5_8) {
7818*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7819*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7820*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7821*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
7822*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7823*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
7824*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7825*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7826*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7827*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7828*4bdc9457SAndroid Build Coastguard Worker }
7829*4bdc9457SAndroid Build Coastguard Worker }
7830*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_8_bw_4)7831*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_8_bw_4) {
7832*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7833*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7834*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7835*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
7836*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7837*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
7838*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7839*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7840*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7841*4bdc9457SAndroid Build Coastguard Worker }
7842*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_5_8_bw_4)7843*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_5_8_bw_4){
7844*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7845*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7846*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7847*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
7848*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7849*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
7850*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7851*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7852*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7853*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7854*4bdc9457SAndroid Build Coastguard Worker }
7855*4bdc9457SAndroid Build Coastguard Worker }
7856*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_5_8_bw_8)7857*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_5_8_bw_8){
7858*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7859*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7860*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7861*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7862*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7863*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
7864*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7865*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7866*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7867*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7868*4bdc9457SAndroid Build Coastguard Worker }
7869*4bdc9457SAndroid Build Coastguard Worker }
7870*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_5_8_bw_5_8)7871*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_5_8_bw_5_8) {
7872*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7873*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
7874*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
7875*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7876*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
7877*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
7878*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7879*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7880*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7881*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7882*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7883*4bdc9457SAndroid Build Coastguard Worker }
7884*4bdc9457SAndroid Build Coastguard Worker }
7885*4bdc9457SAndroid Build Coastguard Worker }
7886*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_4_is_8)7887*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_4_is_8) {
7888*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7889*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7890*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7891*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7892*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7893*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7894*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7895*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7896*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7897*4bdc9457SAndroid Build Coastguard Worker }
7898*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_4_os_8)7899*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_4_os_8) {
7900*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7901*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7902*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
7903*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7904*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7905*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7906*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7907*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7908*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7909*4bdc9457SAndroid Build Coastguard Worker }
7910*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)7911*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
7912*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7913*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7914*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7915*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7916*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7917*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7918*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7919*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7920*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7921*4bdc9457SAndroid Build Coastguard Worker }
7922*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_68_bw_76_ies_15)7923*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_68_bw_76_ies_15) {
7924*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7925*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7926*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
7927*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
7928*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
7929*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
7930*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7931*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
7932*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7933*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7934*4bdc9457SAndroid Build Coastguard Worker }
7935*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_12_bw_20_oes_15)7936*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_12_bw_20_oes_15) {
7937*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7938*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7939*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
7940*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
7941*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
7942*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
7943*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7944*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
7945*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7946*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7947*4bdc9457SAndroid Build Coastguard Worker }
7948*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)7949*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
7950*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7951*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7952*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
7953*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
7954*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
7955*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
7956*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7957*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
7958*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
7959*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7960*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_multi_zip_neon);
7961*4bdc9457SAndroid Build Coastguard Worker }
7962*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
7963*4bdc9457SAndroid Build Coastguard Worker
7964*4bdc9457SAndroid Build Coastguard Worker
7965*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_4)7966*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_4) {
7967*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7968*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7969*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7970*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
7971*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
7972*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
7973*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7974*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7975*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
7976*4bdc9457SAndroid Build Coastguard Worker }
7977*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_1_8_bw_1_8)7978*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_1_8_bw_1_8) {
7979*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7980*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
7981*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
7982*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7983*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
7984*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
7985*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
7986*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
7987*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
7988*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
7989*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
7990*4bdc9457SAndroid Build Coastguard Worker }
7991*4bdc9457SAndroid Build Coastguard Worker }
7992*4bdc9457SAndroid Build Coastguard Worker }
7993*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_8)7994*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_8) {
7995*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
7996*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
7997*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
7998*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
7999*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8000*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8001*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8002*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8003*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8004*4bdc9457SAndroid Build Coastguard Worker }
8005*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_5_8)8006*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_5_8) {
8007*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8008*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8009*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8010*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8011*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8012*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8013*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8014*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8015*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8016*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8017*4bdc9457SAndroid Build Coastguard Worker }
8018*4bdc9457SAndroid Build Coastguard Worker }
8019*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_8_bw_5_8)8020*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_8_bw_5_8) {
8021*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8022*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8023*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8024*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8025*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8026*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8027*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8028*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8029*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8030*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8031*4bdc9457SAndroid Build Coastguard Worker }
8032*4bdc9457SAndroid Build Coastguard Worker }
8033*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_8_bw_4)8034*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_8_bw_4) {
8035*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8036*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8037*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8038*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
8039*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8040*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8041*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8042*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8043*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8044*4bdc9457SAndroid Build Coastguard Worker }
8045*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_5_8_bw_4)8046*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_5_8_bw_4){
8047*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8048*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8049*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8050*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
8051*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8052*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
8053*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8054*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8055*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8056*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8057*4bdc9457SAndroid Build Coastguard Worker }
8058*4bdc9457SAndroid Build Coastguard Worker }
8059*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_5_8_bw_8)8060*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_5_8_bw_8){
8061*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8062*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8063*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8064*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8065*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8066*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8067*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8068*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8069*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8070*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8071*4bdc9457SAndroid Build Coastguard Worker }
8072*4bdc9457SAndroid Build Coastguard Worker }
8073*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_5_8_bw_5_8)8074*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_5_8_bw_5_8) {
8075*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8076*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8077*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
8078*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8079*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
8080*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8081*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8082*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8083*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8084*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8085*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8086*4bdc9457SAndroid Build Coastguard Worker }
8087*4bdc9457SAndroid Build Coastguard Worker }
8088*4bdc9457SAndroid Build Coastguard Worker }
8089*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_4_is_8)8090*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_4_is_8) {
8091*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8092*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8093*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8094*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8095*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8096*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8097*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8098*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8099*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8100*4bdc9457SAndroid Build Coastguard Worker }
8101*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_4_os_8)8102*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_4_os_8) {
8103*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8104*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8105*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8106*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8107*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8108*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8109*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8110*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8111*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8112*4bdc9457SAndroid Build Coastguard Worker }
8113*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)8114*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
8115*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8116*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8117*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8118*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8119*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8120*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8121*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8122*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8123*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8124*4bdc9457SAndroid Build Coastguard Worker }
8125*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_68_bw_76_ies_15)8126*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_68_bw_76_ies_15) {
8127*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8128*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8129*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
8130*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
8131*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
8132*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
8133*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8134*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
8135*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8136*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8137*4bdc9457SAndroid Build Coastguard Worker }
8138*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_12_bw_20_oes_15)8139*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_12_bw_20_oes_15) {
8140*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8141*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8142*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
8143*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
8144*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
8145*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
8146*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8147*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
8148*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8149*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8150*4bdc9457SAndroid Build Coastguard Worker }
8151*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)8152*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
8153*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8154*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8155*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
8156*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
8157*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
8158*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
8159*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8160*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
8161*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
8162*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8163*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_multi_switch_zip_neon);
8164*4bdc9457SAndroid Build Coastguard Worker }
8165*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
8166*4bdc9457SAndroid Build Coastguard Worker
8167*4bdc9457SAndroid Build Coastguard Worker
8168*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_4)8169*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_4) {
8170*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8171*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8172*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8173*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8174*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8175*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8176*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8177*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8179*4bdc9457SAndroid Build Coastguard Worker }
8180*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_1_8_bw_1_8)8181*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_1_8_bw_1_8) {
8182*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8183*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
8184*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
8185*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8186*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
8187*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
8188*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8189*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8190*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8191*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8192*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8193*4bdc9457SAndroid Build Coastguard Worker }
8194*4bdc9457SAndroid Build Coastguard Worker }
8195*4bdc9457SAndroid Build Coastguard Worker }
8196*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_8)8197*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_8) {
8198*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8199*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8200*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8201*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8202*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8203*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8204*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8205*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8206*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8207*4bdc9457SAndroid Build Coastguard Worker }
8208*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_5_8)8209*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_5_8) {
8210*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8211*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8212*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8213*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8214*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8215*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8216*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8217*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8218*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8219*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8220*4bdc9457SAndroid Build Coastguard Worker }
8221*4bdc9457SAndroid Build Coastguard Worker }
8222*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_8_bw_5_8)8223*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_8_bw_5_8) {
8224*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8225*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8226*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8227*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8228*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8229*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8230*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8231*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8232*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8233*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8234*4bdc9457SAndroid Build Coastguard Worker }
8235*4bdc9457SAndroid Build Coastguard Worker }
8236*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_8_bw_4)8237*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_8_bw_4) {
8238*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8239*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8240*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8241*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
8242*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8243*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8244*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8245*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8246*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8247*4bdc9457SAndroid Build Coastguard Worker }
8248*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_5_8_bw_4)8249*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_5_8_bw_4){
8250*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8251*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8252*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8253*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
8254*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8255*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
8256*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8257*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8258*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8259*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8260*4bdc9457SAndroid Build Coastguard Worker }
8261*4bdc9457SAndroid Build Coastguard Worker }
8262*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_5_8_bw_8)8263*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_5_8_bw_8){
8264*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8265*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8266*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8267*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8268*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8269*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8270*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8271*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8272*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8273*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8274*4bdc9457SAndroid Build Coastguard Worker }
8275*4bdc9457SAndroid Build Coastguard Worker }
8276*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_5_8_bw_5_8)8277*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_5_8_bw_5_8) {
8278*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8279*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8280*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
8281*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8282*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
8283*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8284*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8285*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8286*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8287*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8288*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8289*4bdc9457SAndroid Build Coastguard Worker }
8290*4bdc9457SAndroid Build Coastguard Worker }
8291*4bdc9457SAndroid Build Coastguard Worker }
8292*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_4_is_8)8293*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_4_is_8) {
8294*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8295*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8296*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8297*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8298*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8299*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8300*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8301*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8302*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8303*4bdc9457SAndroid Build Coastguard Worker }
8304*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_4_os_8)8305*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_4_os_8) {
8306*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8307*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8308*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8309*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8310*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8311*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8312*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8313*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8314*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8315*4bdc9457SAndroid Build Coastguard Worker }
8316*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)8317*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
8318*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8319*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8320*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8321*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8322*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8323*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8324*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8325*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8326*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8327*4bdc9457SAndroid Build Coastguard Worker }
8328*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_68_bw_76_ies_15)8329*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_68_bw_76_ies_15) {
8330*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8331*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8332*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
8333*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
8334*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
8335*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
8336*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8337*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
8338*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8339*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8340*4bdc9457SAndroid Build Coastguard Worker }
8341*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_12_bw_20_oes_15)8342*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_12_bw_20_oes_15) {
8343*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8344*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8345*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
8346*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
8347*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
8348*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
8349*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8350*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
8351*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8352*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8353*4bdc9457SAndroid Build Coastguard Worker }
8354*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)8355*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
8356*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8357*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8358*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
8359*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
8360*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
8361*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
8362*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8363*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
8364*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
8365*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8366*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_dec_zip_neon);
8367*4bdc9457SAndroid Build Coastguard Worker }
8368*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
8369*4bdc9457SAndroid Build Coastguard Worker
8370*4bdc9457SAndroid Build Coastguard Worker
8371*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_4)8372*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_4) {
8373*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8374*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8375*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8376*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8377*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8378*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8379*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8380*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8381*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8382*4bdc9457SAndroid Build Coastguard Worker }
8383*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_1_8_bw_1_8)8384*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_1_8_bw_1_8) {
8385*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8386*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
8387*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
8388*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8389*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
8390*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
8391*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8392*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8393*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8394*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8395*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8396*4bdc9457SAndroid Build Coastguard Worker }
8397*4bdc9457SAndroid Build Coastguard Worker }
8398*4bdc9457SAndroid Build Coastguard Worker }
8399*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_8)8400*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_8) {
8401*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8402*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8403*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8404*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8405*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8406*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8407*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8408*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8409*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8410*4bdc9457SAndroid Build Coastguard Worker }
8411*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_5_8)8412*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_5_8) {
8413*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8414*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8415*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8416*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8417*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8418*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8419*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8420*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8421*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8422*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8423*4bdc9457SAndroid Build Coastguard Worker }
8424*4bdc9457SAndroid Build Coastguard Worker }
8425*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_8_bw_5_8)8426*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_8_bw_5_8) {
8427*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8428*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8429*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8430*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8431*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8432*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8433*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8434*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8435*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8436*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8437*4bdc9457SAndroid Build Coastguard Worker }
8438*4bdc9457SAndroid Build Coastguard Worker }
8439*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_8_bw_4)8440*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_8_bw_4) {
8441*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8442*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8443*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8444*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
8445*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8446*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8447*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8450*4bdc9457SAndroid Build Coastguard Worker }
8451*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_5_8_bw_4)8452*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_5_8_bw_4){
8453*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8454*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8455*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8456*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
8457*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8458*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
8459*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8460*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8461*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8462*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8463*4bdc9457SAndroid Build Coastguard Worker }
8464*4bdc9457SAndroid Build Coastguard Worker }
8465*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_5_8_bw_8)8466*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_5_8_bw_8){
8467*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8468*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8469*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8470*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8471*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8472*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8473*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8474*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8475*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8476*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8477*4bdc9457SAndroid Build Coastguard Worker }
8478*4bdc9457SAndroid Build Coastguard Worker }
8479*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_5_8_bw_5_8)8480*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_5_8_bw_5_8) {
8481*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8482*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8483*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
8484*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8485*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
8486*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8487*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8488*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8489*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8490*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8491*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8492*4bdc9457SAndroid Build Coastguard Worker }
8493*4bdc9457SAndroid Build Coastguard Worker }
8494*4bdc9457SAndroid Build Coastguard Worker }
8495*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_4_is_8)8496*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_4_is_8) {
8497*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8498*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8499*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8500*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8501*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8502*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8503*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8504*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8505*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8506*4bdc9457SAndroid Build Coastguard Worker }
8507*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_4_os_8)8508*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_4_os_8) {
8509*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8510*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8511*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8512*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8513*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8514*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8515*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8516*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8517*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8518*4bdc9457SAndroid Build Coastguard Worker }
8519*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)8520*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
8521*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8522*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8523*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8524*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8525*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8526*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8527*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8528*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8529*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8530*4bdc9457SAndroid Build Coastguard Worker }
8531*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_68_bw_76_ies_15)8532*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_68_bw_76_ies_15) {
8533*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8534*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8535*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
8536*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
8537*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
8538*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
8539*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8540*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
8541*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8542*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8543*4bdc9457SAndroid Build Coastguard Worker }
8544*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_12_bw_20_oes_15)8545*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_12_bw_20_oes_15) {
8546*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8547*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8548*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
8549*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
8550*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
8551*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
8552*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8553*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
8554*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8555*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8556*4bdc9457SAndroid Build Coastguard Worker }
8557*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)8558*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
8559*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8560*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8561*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
8562*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
8563*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
8564*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
8565*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8566*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
8567*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
8568*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8569*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_mov_zip_neon);
8570*4bdc9457SAndroid Build Coastguard Worker }
8571*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
8572*4bdc9457SAndroid Build Coastguard Worker
8573*4bdc9457SAndroid Build Coastguard Worker
8574*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_4)8575*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_4) {
8576*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8577*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8578*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8579*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8580*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8581*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8582*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8583*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8584*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8585*4bdc9457SAndroid Build Coastguard Worker }
8586*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_1_8_bw_1_8)8587*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_1_8_bw_1_8) {
8588*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8589*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
8590*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
8591*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8592*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
8593*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
8594*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8595*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8596*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8597*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8598*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8599*4bdc9457SAndroid Build Coastguard Worker }
8600*4bdc9457SAndroid Build Coastguard Worker }
8601*4bdc9457SAndroid Build Coastguard Worker }
8602*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_8)8603*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_8) {
8604*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8605*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8606*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8607*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8608*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8609*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8610*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8611*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8612*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8613*4bdc9457SAndroid Build Coastguard Worker }
8614*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_5_8)8615*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_5_8) {
8616*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8617*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8618*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8619*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8620*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8621*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8622*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8623*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8624*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8625*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8626*4bdc9457SAndroid Build Coastguard Worker }
8627*4bdc9457SAndroid Build Coastguard Worker }
8628*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_8_bw_5_8)8629*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_8_bw_5_8) {
8630*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8631*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8632*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8633*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8634*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8635*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8636*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8637*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8638*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8639*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8640*4bdc9457SAndroid Build Coastguard Worker }
8641*4bdc9457SAndroid Build Coastguard Worker }
8642*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_8_bw_4)8643*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_8_bw_4) {
8644*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8645*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8646*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8647*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
8648*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8649*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8650*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8651*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8652*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8653*4bdc9457SAndroid Build Coastguard Worker }
8654*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_5_8_bw_4)8655*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_5_8_bw_4){
8656*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8657*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8658*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8659*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
8660*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8661*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
8662*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8663*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8664*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8665*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8666*4bdc9457SAndroid Build Coastguard Worker }
8667*4bdc9457SAndroid Build Coastguard Worker }
8668*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_5_8_bw_8)8669*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_5_8_bw_8){
8670*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8671*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8672*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8673*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8674*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8675*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8676*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8677*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8678*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8679*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8680*4bdc9457SAndroid Build Coastguard Worker }
8681*4bdc9457SAndroid Build Coastguard Worker }
8682*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_5_8_bw_5_8)8683*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_5_8_bw_5_8) {
8684*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8685*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8686*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
8687*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8688*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
8689*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8690*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8691*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8692*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8693*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8694*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8695*4bdc9457SAndroid Build Coastguard Worker }
8696*4bdc9457SAndroid Build Coastguard Worker }
8697*4bdc9457SAndroid Build Coastguard Worker }
8698*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_4_is_8)8699*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_4_is_8) {
8700*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8701*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8702*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8703*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8704*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8705*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8706*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8707*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8708*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8709*4bdc9457SAndroid Build Coastguard Worker }
8710*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_4_os_8)8711*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_4_os_8) {
8712*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8713*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8714*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8715*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8716*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8717*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8718*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8719*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8721*4bdc9457SAndroid Build Coastguard Worker }
8722*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)8723*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
8724*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8725*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8726*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8727*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8728*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8729*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8730*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8731*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8732*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8733*4bdc9457SAndroid Build Coastguard Worker }
8734*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_68_bw_76_ies_15)8735*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_68_bw_76_ies_15) {
8736*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8737*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8738*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
8739*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
8740*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
8741*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
8742*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8743*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
8744*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8745*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8746*4bdc9457SAndroid Build Coastguard Worker }
8747*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_12_bw_20_oes_15)8748*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_12_bw_20_oes_15) {
8749*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8750*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8751*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
8752*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
8753*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
8754*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
8755*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8756*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
8757*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8758*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8759*4bdc9457SAndroid Build Coastguard Worker }
8760*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)8761*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
8762*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8763*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8764*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
8765*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
8766*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
8767*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
8768*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8769*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
8770*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
8771*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8772*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_multi_zip_neon);
8773*4bdc9457SAndroid Build Coastguard Worker }
8774*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
8775*4bdc9457SAndroid Build Coastguard Worker
8776*4bdc9457SAndroid Build Coastguard Worker
8777*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_4)8778*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_4) {
8779*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8780*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8781*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8782*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8783*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8784*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8785*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8786*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8787*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8788*4bdc9457SAndroid Build Coastguard Worker }
8789*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_1_8_bw_1_8)8790*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_1_8_bw_1_8) {
8791*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8792*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
8793*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
8794*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8795*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
8796*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
8797*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8798*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8799*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8800*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8801*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8802*4bdc9457SAndroid Build Coastguard Worker }
8803*4bdc9457SAndroid Build Coastguard Worker }
8804*4bdc9457SAndroid Build Coastguard Worker }
8805*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_8)8806*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_8) {
8807*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8808*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8809*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8810*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8811*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8812*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8813*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8814*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8815*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8816*4bdc9457SAndroid Build Coastguard Worker }
8817*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_5_8)8818*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_5_8) {
8819*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8820*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8821*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8822*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8823*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8824*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8825*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8826*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8827*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8828*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8829*4bdc9457SAndroid Build Coastguard Worker }
8830*4bdc9457SAndroid Build Coastguard Worker }
8831*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_8_bw_5_8)8832*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_8_bw_5_8) {
8833*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8834*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8835*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8836*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
8837*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8838*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
8839*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8840*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8841*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8842*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8843*4bdc9457SAndroid Build Coastguard Worker }
8844*4bdc9457SAndroid Build Coastguard Worker }
8845*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_8_bw_4)8846*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_8_bw_4) {
8847*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8848*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8849*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8850*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
8851*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8852*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
8853*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8854*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8855*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8856*4bdc9457SAndroid Build Coastguard Worker }
8857*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_5_8_bw_4)8858*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_5_8_bw_4){
8859*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8860*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8861*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8862*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
8863*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8864*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
8865*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8866*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8867*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8868*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8869*4bdc9457SAndroid Build Coastguard Worker }
8870*4bdc9457SAndroid Build Coastguard Worker }
8871*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_5_8_bw_8)8872*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_5_8_bw_8){
8873*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8874*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8875*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8876*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8877*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8878*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
8879*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8880*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8881*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8882*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8883*4bdc9457SAndroid Build Coastguard Worker }
8884*4bdc9457SAndroid Build Coastguard Worker }
8885*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_5_8_bw_5_8)8886*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_5_8_bw_5_8) {
8887*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8888*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
8889*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
8890*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8891*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
8892*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
8893*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
8894*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
8895*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8896*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8897*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8898*4bdc9457SAndroid Build Coastguard Worker }
8899*4bdc9457SAndroid Build Coastguard Worker }
8900*4bdc9457SAndroid Build Coastguard Worker }
8901*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_4_is_8)8902*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_4_is_8) {
8903*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8904*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8905*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8906*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
8907*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8908*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8909*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8910*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8911*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8912*4bdc9457SAndroid Build Coastguard Worker }
8913*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_4_os_8)8914*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_4_os_8) {
8915*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8916*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8917*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
8918*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8919*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8920*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8921*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8922*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8923*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8924*4bdc9457SAndroid Build Coastguard Worker }
8925*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_4_bw_4_is_8_os_8)8926*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_4_bw_4_is_8_os_8) {
8927*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8928*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8929*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
8930*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
8931*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
8932*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
8933*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8934*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8935*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8936*4bdc9457SAndroid Build Coastguard Worker }
8937*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_68_bw_76_ies_15)8938*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_68_bw_76_ies_15) {
8939*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8940*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8941*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
8942*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
8943*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
8944*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
8945*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8946*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(15)
8947*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8948*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8949*4bdc9457SAndroid Build Coastguard Worker }
8950*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_12_bw_20_oes_15)8951*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_12_bw_20_oes_15) {
8952*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8953*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8954*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
8955*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
8956*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
8957*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
8958*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8959*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
8960*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8961*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8962*4bdc9457SAndroid Build Coastguard Worker }
8963*4bdc9457SAndroid Build Coastguard Worker
TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4,bh_28_bw_92_ies_21_oes_17)8964*4bdc9457SAndroid Build Coastguard Worker TEST(X32_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_4, bh_28_bw_92_ies_21_oes_17) {
8965*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
8966*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
8967*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
8968*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
8969*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
8970*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
8971*4bdc9457SAndroid Build Coastguard Worker .element_size(4)
8972*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(21)
8973*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(17)
8974*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
8975*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x32_transposec_ukernel__4x4_reuse_switch_zip_neon);
8976*4bdc9457SAndroid Build Coastguard Worker }
8977*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
8978