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/x16-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(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_2)20*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
27*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
28*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
29*4bdc9457SAndroid Build Coastguard Worker }
30*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_2_bw_1_4)31*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
40*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
41*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
42*4bdc9457SAndroid Build Coastguard Worker }
43*4bdc9457SAndroid Build Coastguard Worker }
44*4bdc9457SAndroid Build Coastguard Worker }
45*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_4)46*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
53*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
54*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
55*4bdc9457SAndroid Build Coastguard Worker }
56*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_3_4)57*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
65*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
66*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
67*4bdc9457SAndroid Build Coastguard Worker }
68*4bdc9457SAndroid Build Coastguard Worker }
69*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_2_bw_3_4)70*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
78*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
79*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
80*4bdc9457SAndroid Build Coastguard Worker }
81*4bdc9457SAndroid Build Coastguard Worker }
82*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_2_bw_2)83*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
90*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
91*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
92*4bdc9457SAndroid Build Coastguard Worker }
93*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_2_2_bw_2)94*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
102*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
103*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
104*4bdc9457SAndroid Build Coastguard Worker }
105*4bdc9457SAndroid Build Coastguard Worker }
106*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_2_2_bw_4)107*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
115*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
116*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
117*4bdc9457SAndroid Build Coastguard Worker }
118*4bdc9457SAndroid Build Coastguard Worker }
119*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_2_2_bw_3_4)120*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
129*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
130*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
131*4bdc9457SAndroid Build Coastguard Worker }
132*4bdc9457SAndroid Build Coastguard Worker }
133*4bdc9457SAndroid Build Coastguard Worker }
134*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_2_is_4)135*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
142*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
143*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
144*4bdc9457SAndroid Build Coastguard Worker }
145*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_2_os_2)146*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
153*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
155*4bdc9457SAndroid Build Coastguard Worker }
156*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_1_bw_2_is_4_os_2)157*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, 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(2)
164*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
166*4bdc9457SAndroid Build Coastguard Worker }
167*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_17_bw_38_ies_13)168*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, bh_17_bw_38_ies_13) {
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(2)
175*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
176*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
178*4bdc9457SAndroid Build Coastguard Worker }
179*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_3_bw_10_oes_13)180*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, bh_3_bw_10_oes_13) {
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(2)
187*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
190*4bdc9457SAndroid Build Coastguard Worker }
191*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2,bh_7_bw_46_ies_19_oes_15)192*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X2_SCALAR_INT_2, bh_7_bw_46_ies_19_oes_15) {
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(2)
199*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
200*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
201*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
202*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x2_scalar_int);
203*4bdc9457SAndroid Build Coastguard Worker }
204*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_4)205*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_4) {
206*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
207*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
208*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
209*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
210*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
211*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
214*4bdc9457SAndroid Build Coastguard Worker }
215*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_2_bw_1_8)216*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_2_bw_1_8) {
217*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 2; ++i){
218*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++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(2)
225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
227*4bdc9457SAndroid Build Coastguard Worker }
228*4bdc9457SAndroid Build Coastguard Worker }
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_8)231*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_8) {
232*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
233*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
234*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
235*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
236*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
237*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
238*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
239*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
240*4bdc9457SAndroid Build Coastguard Worker }
241*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_5_8)242*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_5_8) {
243*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
250*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
251*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
252*4bdc9457SAndroid Build Coastguard Worker }
253*4bdc9457SAndroid Build Coastguard Worker }
254*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_2_bw_5_8)255*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_2_bw_5_8) {
256*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
265*4bdc9457SAndroid Build Coastguard Worker }
266*4bdc9457SAndroid Build Coastguard Worker }
267*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_2_bw_4)268*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_2_bw_4) {
269*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
270*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
271*4bdc9457SAndroid Build Coastguard Worker .output_stride(7)
272*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
273*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
274*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
275*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
276*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
277*4bdc9457SAndroid Build Coastguard Worker }
278*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_2_2_bw_4)279*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_2_2_bw_4){
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(21)
283*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
284*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
285*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
286*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
287*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
288*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
289*4bdc9457SAndroid Build Coastguard Worker }
290*4bdc9457SAndroid Build Coastguard Worker }
291*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_2_2_bw_8)292*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_2_2_bw_8){
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(8)
296*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
297*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
298*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
299*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
300*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
301*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
302*4bdc9457SAndroid Build Coastguard Worker }
303*4bdc9457SAndroid Build Coastguard Worker }
304*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_2_2_bw_5_8)305*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_2_2_bw_5_8) {
306*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
307*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++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(2)
314*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
315*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
316*4bdc9457SAndroid Build Coastguard Worker }
317*4bdc9457SAndroid Build Coastguard Worker }
318*4bdc9457SAndroid Build Coastguard Worker }
319*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_4_is_8)320*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_4_is_8) {
321*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
322*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
323*4bdc9457SAndroid Build Coastguard Worker .output_stride(1)
324*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
325*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
326*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
327*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
328*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
329*4bdc9457SAndroid Build Coastguard Worker }
330*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_4_os_2)331*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_4_os_2) {
332*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
333*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
334*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
335*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
336*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
337*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
338*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
339*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
340*4bdc9457SAndroid Build Coastguard Worker }
341*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_1_bw_4_is_8_os_2)342*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_1_bw_4_is_8_os_2) {
343*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
344*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
345*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
346*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
347*4bdc9457SAndroid Build Coastguard Worker .block_height(1)
348*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
351*4bdc9457SAndroid Build Coastguard Worker }
352*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_17_bw_76_ies_13)353*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_17_bw_76_ies_13) {
354*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
355*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
356*4bdc9457SAndroid Build Coastguard Worker .output_stride(17)
357*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
358*4bdc9457SAndroid Build Coastguard Worker .block_height(17)
359*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
360*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
361*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
362*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
363*4bdc9457SAndroid Build Coastguard Worker }
364*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_3_bw_20_oes_13)365*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_3_bw_20_oes_13) {
366*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
367*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
368*4bdc9457SAndroid Build Coastguard Worker .output_stride(3)
369*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
370*4bdc9457SAndroid Build Coastguard Worker .block_height(3)
371*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
372*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
375*4bdc9457SAndroid Build Coastguard Worker }
376*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2,bh_7_bw_92_ies_19_oes_15)377*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__1X4_SCALAR_INT_2, bh_7_bw_92_ies_19_oes_15) {
378*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
379*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
380*4bdc9457SAndroid Build Coastguard Worker .output_stride(13)
381*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
382*4bdc9457SAndroid Build Coastguard Worker .block_height(7)
383*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
384*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
385*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
386*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
387*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__1x4_scalar_int);
388*4bdc9457SAndroid Build Coastguard Worker }
389*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_1)390*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_1) {
391*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
392*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
393*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
394*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
395*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
396*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
399*4bdc9457SAndroid Build Coastguard Worker }
400*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_1_4_bw_1_2)401*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_1_4_bw_1_2) {
402*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
403*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 2; ++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(2)
410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
412*4bdc9457SAndroid Build Coastguard Worker }
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker }
415*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_2)416*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_2) {
417*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
418*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
419*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
420*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
421*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
422*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
423*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
424*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
425*4bdc9457SAndroid Build Coastguard Worker }
426*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_2_2)427*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_2_2) {
428*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
429*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
430*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
431*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
432*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
433*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
434*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
435*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
436*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
437*4bdc9457SAndroid Build Coastguard Worker }
438*4bdc9457SAndroid Build Coastguard Worker }
439*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_4_bw_2_2)440*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_4_bw_2_2) {
441*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 2; i < 2; ++i){
442*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
443*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
444*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
445*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
446*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
447*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
450*4bdc9457SAndroid Build Coastguard Worker }
451*4bdc9457SAndroid Build Coastguard Worker }
452*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_4_bw_1)453*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_4_bw_1) {
454*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
455*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
456*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
457*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
458*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
459*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
460*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
461*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
462*4bdc9457SAndroid Build Coastguard Worker }
463*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_3_4_bw_1)464*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_3_4_bw_1){
465*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
466*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
467*4bdc9457SAndroid Build Coastguard Worker .input_stride(18)
468*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
469*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
470*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
471*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
472*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
473*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
474*4bdc9457SAndroid Build Coastguard Worker }
475*4bdc9457SAndroid Build Coastguard Worker }
476*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_3_4_bw_2)477*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_3_4_bw_2){
478*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
479*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
480*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
481*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
482*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
483*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
484*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
485*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
486*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
487*4bdc9457SAndroid Build Coastguard Worker }
488*4bdc9457SAndroid Build Coastguard Worker }
489*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_3_4_bw_2_2)490*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_3_4_bw_2_2) {
491*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
492*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 2; j < 2; ++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(2)
499*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
500*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
501*4bdc9457SAndroid Build Coastguard Worker }
502*4bdc9457SAndroid Build Coastguard Worker }
503*4bdc9457SAndroid Build Coastguard Worker }
504*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_1_is_2)505*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_1_is_2) {
506*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
507*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
508*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
509*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
510*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
511*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
512*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
513*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
514*4bdc9457SAndroid Build Coastguard Worker }
515*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_1_os_4)516*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_1_os_4) {
517*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
518*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
519*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
520*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
521*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
522*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_2_bw_1_is_2_os_4)527*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_2_bw_1_is_2_os_4) {
528*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
529*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
530*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
531*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
532*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
533*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
536*4bdc9457SAndroid Build Coastguard Worker }
537*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_34_bw_19_ies_13)538*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_34_bw_19_ies_13) {
539*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
540*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
541*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
542*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
543*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
544*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
545*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
546*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
547*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
548*4bdc9457SAndroid Build Coastguard Worker }
549*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_6_bw_5_oes_13)550*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_6_bw_5_oes_13) {
551*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
552*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
553*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
554*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
555*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
556*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
557*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
560*4bdc9457SAndroid Build Coastguard Worker }
561*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2,bh_14_bw_23_ies_19_oes_15)562*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X1_SCALAR_INT_2, bh_14_bw_23_ies_19_oes_15) {
563*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
564*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
565*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
566*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
567*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
568*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
569*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
570*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
571*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
572*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x1_scalar_int);
573*4bdc9457SAndroid Build Coastguard Worker }
574*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_2)575*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_2) {
576*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
577*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
578*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
579*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
580*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
581*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
582*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
583*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_1_4_bw_1_4)586*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_1_4_bw_1_4) {
587*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
588*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++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(2)
595*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
597*4bdc9457SAndroid Build Coastguard Worker }
598*4bdc9457SAndroid Build Coastguard Worker }
599*4bdc9457SAndroid Build Coastguard Worker }
600*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_4)601*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_4) {
602*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
603*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
604*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
605*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
606*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
607*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
608*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
609*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
610*4bdc9457SAndroid Build Coastguard Worker }
611*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_3_4)612*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_3_4) {
613*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
614*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
615*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
616*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
617*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
618*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
619*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
620*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
621*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
622*4bdc9457SAndroid Build Coastguard Worker }
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_4_bw_3_4)625*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_4_bw_3_4) {
626*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
628*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
629*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
630*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
631*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
632*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_4_bw_2)638*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_4_bw_2) {
639*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
640*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
641*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
642*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
643*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
644*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
647*4bdc9457SAndroid Build Coastguard Worker }
648*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_3_4_bw_2)649*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_3_4_bw_2){
650*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
651*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
652*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
653*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
654*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
655*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
656*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
659*4bdc9457SAndroid Build Coastguard Worker }
660*4bdc9457SAndroid Build Coastguard Worker }
661*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_3_4_bw_4)662*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_3_4_bw_4){
663*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
664*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
665*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
666*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
667*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
668*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
669*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
672*4bdc9457SAndroid Build Coastguard Worker }
673*4bdc9457SAndroid Build Coastguard Worker }
674*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_3_4_bw_3_4)675*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_3_4_bw_3_4) {
676*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
677*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++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(2)
684*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
685*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
686*4bdc9457SAndroid Build Coastguard Worker }
687*4bdc9457SAndroid Build Coastguard Worker }
688*4bdc9457SAndroid Build Coastguard Worker }
689*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_2_is_4)690*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_2_is_4) {
691*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
692*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
693*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
694*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
695*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
696*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
699*4bdc9457SAndroid Build Coastguard Worker }
700*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_2_os_4)701*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_2_os_4) {
702*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
703*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
704*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
705*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
706*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
707*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
708*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
709*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
710*4bdc9457SAndroid Build Coastguard Worker }
711*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_2_bw_2_is_4_os_4)712*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_2_bw_2_is_4_os_4) {
713*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
714*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
715*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
716*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
717*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
718*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
719*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
721*4bdc9457SAndroid Build Coastguard Worker }
722*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_34_bw_38_ies_13)723*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_34_bw_38_ies_13) {
724*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
725*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
726*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
727*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
728*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
729*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
730*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
731*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
732*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
733*4bdc9457SAndroid Build Coastguard Worker }
734*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_6_bw_10_oes_13)735*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_6_bw_10_oes_13) {
736*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
737*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
738*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
739*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
740*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
741*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
742*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
743*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
745*4bdc9457SAndroid Build Coastguard Worker }
746*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2,bh_14_bw_46_ies_19_oes_15)747*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X2_SCALAR_INT_2, bh_14_bw_46_ies_19_oes_15) {
748*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
749*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
750*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
751*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
752*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
753*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
754*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
755*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
756*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x2_scalar_int);
758*4bdc9457SAndroid Build Coastguard Worker }
759*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_4)760*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_4) {
761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
762*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
763*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
764*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
765*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
766*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
769*4bdc9457SAndroid Build Coastguard Worker }
770*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_1_4_bw_1_8)771*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_1_4_bw_1_8) {
772*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
773*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++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(2)
780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
782*4bdc9457SAndroid Build Coastguard Worker }
783*4bdc9457SAndroid Build Coastguard Worker }
784*4bdc9457SAndroid Build Coastguard Worker }
785*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_8)786*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_8) {
787*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
788*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
789*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
790*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
791*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
792*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
795*4bdc9457SAndroid Build Coastguard Worker }
796*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_5_8)797*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_5_8) {
798*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
805*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
806*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
807*4bdc9457SAndroid Build Coastguard Worker }
808*4bdc9457SAndroid Build Coastguard Worker }
809*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_4_bw_5_8)810*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_4_bw_5_8) {
811*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
818*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
820*4bdc9457SAndroid Build Coastguard Worker }
821*4bdc9457SAndroid Build Coastguard Worker }
822*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_4_bw_4)823*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_4_bw_4) {
824*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
825*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
826*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
827*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
828*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
829*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
830*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
831*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
832*4bdc9457SAndroid Build Coastguard Worker }
833*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_3_4_bw_4)834*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_3_4_bw_4){
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(21)
838*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
839*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
840*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
841*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
842*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
843*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
844*4bdc9457SAndroid Build Coastguard Worker }
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_3_4_bw_8)847*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_3_4_bw_8){
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(8)
851*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
852*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
853*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
854*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
855*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
856*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
857*4bdc9457SAndroid Build Coastguard Worker }
858*4bdc9457SAndroid Build Coastguard Worker }
859*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_3_4_bw_5_8)860*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_3_4_bw_5_8) {
861*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
862*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++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(2)
869*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
870*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
871*4bdc9457SAndroid Build Coastguard Worker }
872*4bdc9457SAndroid Build Coastguard Worker }
873*4bdc9457SAndroid Build Coastguard Worker }
874*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_4_is_8)875*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_4_is_8) {
876*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
877*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
878*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
879*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
880*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
881*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
882*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
883*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
884*4bdc9457SAndroid Build Coastguard Worker }
885*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_4_os_4)886*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_4_os_4) {
887*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
888*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
889*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
890*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
891*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
892*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
893*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
894*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_2_bw_4_is_8_os_4)897*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_2_bw_4_is_8_os_4) {
898*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
899*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
900*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
901*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
902*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
903*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
904*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
905*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
906*4bdc9457SAndroid Build Coastguard Worker }
907*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_34_bw_76_ies_13)908*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_34_bw_76_ies_13) {
909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
910*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
911*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
912*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
913*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
914*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
915*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
916*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
917*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
918*4bdc9457SAndroid Build Coastguard Worker }
919*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_6_bw_20_oes_13)920*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_6_bw_20_oes_13) {
921*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
922*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
923*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
924*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
925*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
926*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
927*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
930*4bdc9457SAndroid Build Coastguard Worker }
931*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2,bh_14_bw_92_ies_19_oes_15)932*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__2X4_SCALAR_INT_2, bh_14_bw_92_ies_19_oes_15) {
933*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
934*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
935*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
936*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
937*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
938*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
939*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
940*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
941*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
942*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__2x4_scalar_int);
943*4bdc9457SAndroid Build Coastguard Worker }
944*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_1)945*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_bw_1) {
946*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
947*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
948*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
949*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
950*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
951*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
952*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
953*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
954*4bdc9457SAndroid Build Coastguard Worker }
955*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_1_8_bw_1_2)956*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_1_8_bw_1_2) {
957*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++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(2)
965*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
967*4bdc9457SAndroid Build Coastguard Worker }
968*4bdc9457SAndroid Build Coastguard Worker }
969*4bdc9457SAndroid Build Coastguard Worker }
970*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_2)971*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_bw_2) {
972*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
973*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
974*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
975*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
976*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
977*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
978*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
979*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
980*4bdc9457SAndroid Build Coastguard Worker }
981*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_2_2)982*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_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(8)
987*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
988*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
989*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
990*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
991*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
992*4bdc9457SAndroid Build Coastguard Worker }
993*4bdc9457SAndroid Build Coastguard Worker }
994*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_8_bw_2_2)995*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_8_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(8)
1000*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1001*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1002*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1003*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1005*4bdc9457SAndroid Build Coastguard Worker }
1006*4bdc9457SAndroid Build Coastguard Worker }
1007*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_8_bw_1)1008*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_8_bw_1) {
1009*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1010*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1011*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1012*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1013*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1014*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1015*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1016*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1017*4bdc9457SAndroid Build Coastguard Worker }
1018*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_5_8_bw_1)1019*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_5_8_bw_1){
1020*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1027*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1029*4bdc9457SAndroid Build Coastguard Worker }
1030*4bdc9457SAndroid Build Coastguard Worker }
1031*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_5_8_bw_2)1032*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_5_8_bw_2){
1033*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1040*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1042*4bdc9457SAndroid Build Coastguard Worker }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_5_8_bw_2_2)1045*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_5_8_bw_2_2) {
1046*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1054*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1055*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1056*4bdc9457SAndroid Build Coastguard Worker }
1057*4bdc9457SAndroid Build Coastguard Worker }
1058*4bdc9457SAndroid Build Coastguard Worker }
1059*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_1_is_2)1060*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_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(4)
1064*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1065*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1066*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1067*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1068*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_1_os_8)1071*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_bw_1_os_8) {
1072*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1073*4bdc9457SAndroid Build Coastguard Worker .input_stride(1)
1074*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1075*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1076*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1077*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1078*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1079*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1080*4bdc9457SAndroid Build Coastguard Worker }
1081*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_4_bw_1_is_2_os_8)1082*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_4_bw_1_is_2_os_8) {
1083*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1084*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1085*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1086*4bdc9457SAndroid Build Coastguard Worker .block_width(1)
1087*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1088*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1091*4bdc9457SAndroid Build Coastguard Worker }
1092*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_68_bw_19_ies_13)1093*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_68_bw_19_ies_13) {
1094*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1095*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
1096*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
1097*4bdc9457SAndroid Build Coastguard Worker .block_width(19)
1098*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
1099*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1100*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
1101*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1102*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1103*4bdc9457SAndroid Build Coastguard Worker }
1104*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_12_bw_5_oes_13)1105*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_12_bw_5_oes_13) {
1106*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1107*4bdc9457SAndroid Build Coastguard Worker .input_stride(5)
1108*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
1109*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
1110*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
1111*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1112*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
1113*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1115*4bdc9457SAndroid Build Coastguard Worker }
1116*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2,bh_28_bw_23_ies_19_oes_15)1117*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X1_SCALAR_INT_2, bh_28_bw_23_ies_19_oes_15) {
1118*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1119*4bdc9457SAndroid Build Coastguard Worker .input_stride(28)
1120*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1121*4bdc9457SAndroid Build Coastguard Worker .block_width(23)
1122*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
1123*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1124*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
1125*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1126*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1127*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x1_scalar_int);
1128*4bdc9457SAndroid Build Coastguard Worker }
1129*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_2)1130*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_bw_2) {
1131*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1132*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1133*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1134*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1135*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1136*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1139*4bdc9457SAndroid Build Coastguard Worker }
1140*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_1_8_bw_1_4)1141*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_1_8_bw_1_4) {
1142*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++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(2)
1150*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1152*4bdc9457SAndroid Build Coastguard Worker }
1153*4bdc9457SAndroid Build Coastguard Worker }
1154*4bdc9457SAndroid Build Coastguard Worker }
1155*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_4)1156*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_bw_4) {
1157*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1158*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1159*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1160*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1161*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1162*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1163*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1165*4bdc9457SAndroid Build Coastguard Worker }
1166*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_3_4)1167*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_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(8)
1172*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1173*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1174*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1175*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1176*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1177*4bdc9457SAndroid Build Coastguard Worker }
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_8_bw_3_4)1180*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_8_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(8)
1185*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1186*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1187*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1190*4bdc9457SAndroid Build Coastguard Worker }
1191*4bdc9457SAndroid Build Coastguard Worker }
1192*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_8_bw_2)1193*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_8_bw_2) {
1194*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1195*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1196*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1197*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1198*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1199*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1200*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1201*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1202*4bdc9457SAndroid Build Coastguard Worker }
1203*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_5_8_bw_2)1204*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_5_8_bw_2){
1205*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1214*4bdc9457SAndroid Build Coastguard Worker }
1215*4bdc9457SAndroid Build Coastguard Worker }
1216*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_5_8_bw_4)1217*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_5_8_bw_4){
1218*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker }
1229*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_5_8_bw_3_4)1230*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_5_8_bw_3_4) {
1231*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++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(2)
1239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1241*4bdc9457SAndroid Build Coastguard Worker }
1242*4bdc9457SAndroid Build Coastguard Worker }
1243*4bdc9457SAndroid Build Coastguard Worker }
1244*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_2_is_4)1245*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_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(4)
1249*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1250*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1251*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1252*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_2_os_8)1256*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_bw_2_os_8) {
1257*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1258*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1259*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1260*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1261*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1262*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_4_bw_2_is_4_os_8)1267*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_4_bw_2_is_4_os_8) {
1268*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1269*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1270*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1271*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1272*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1273*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1274*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1275*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1276*4bdc9457SAndroid Build Coastguard Worker }
1277*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_68_bw_38_ies_13)1278*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_68_bw_38_ies_13) {
1279*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1280*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
1281*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
1282*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
1283*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
1284*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1285*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
1286*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1287*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1288*4bdc9457SAndroid Build Coastguard Worker }
1289*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_12_bw_10_oes_13)1290*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_12_bw_10_oes_13) {
1291*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1292*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
1293*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
1294*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
1295*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
1296*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1297*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
1298*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1300*4bdc9457SAndroid Build Coastguard Worker }
1301*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2,bh_28_bw_46_ies_19_oes_15)1302*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X2_SCALAR_INT_2, bh_28_bw_46_ies_19_oes_15) {
1303*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1304*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
1305*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1306*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
1307*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
1308*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1309*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
1310*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1311*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1312*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x2_scalar_int);
1313*4bdc9457SAndroid Build Coastguard Worker }
1314*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_4)1315*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_4) {
1316*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1317*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1318*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1319*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1320*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1321*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1322*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1324*4bdc9457SAndroid Build Coastguard Worker }
1325*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_1_8_bw_1_8)1326*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_1_8_bw_1_8) {
1327*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
1328*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++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(2)
1335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1337*4bdc9457SAndroid Build Coastguard Worker }
1338*4bdc9457SAndroid Build Coastguard Worker }
1339*4bdc9457SAndroid Build Coastguard Worker }
1340*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_8)1341*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_8) {
1342*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1343*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1344*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1345*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1346*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1347*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1348*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1349*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1350*4bdc9457SAndroid Build Coastguard Worker }
1351*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_5_8)1352*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_5_8) {
1353*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1354*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1355*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1356*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1357*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1358*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1359*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1360*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1361*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1362*4bdc9457SAndroid Build Coastguard Worker }
1363*4bdc9457SAndroid Build Coastguard Worker }
1364*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_8_bw_5_8)1365*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_8_bw_5_8) {
1366*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1367*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1368*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1369*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1370*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1371*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1372*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1375*4bdc9457SAndroid Build Coastguard Worker }
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_8_bw_4)1378*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_8_bw_4) {
1379*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1380*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1381*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1382*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1383*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1384*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1385*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1386*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1387*4bdc9457SAndroid Build Coastguard Worker }
1388*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_5_8_bw_4)1389*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_5_8_bw_4){
1390*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1391*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1392*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
1393*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1394*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
1395*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1396*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1399*4bdc9457SAndroid Build Coastguard Worker }
1400*4bdc9457SAndroid Build Coastguard Worker }
1401*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_5_8_bw_8)1402*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_5_8_bw_8){
1403*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1404*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1405*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1406*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1407*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1408*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1409*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_5_8_bw_5_8)1415*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_5_8_bw_5_8) {
1416*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1417*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++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(2)
1424*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1425*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1426*4bdc9457SAndroid Build Coastguard Worker }
1427*4bdc9457SAndroid Build Coastguard Worker }
1428*4bdc9457SAndroid Build Coastguard Worker }
1429*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_4_is_8)1430*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_4_is_8) {
1431*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1432*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1433*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1434*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1435*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1436*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1437*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1438*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1439*4bdc9457SAndroid Build Coastguard Worker }
1440*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_4_os_8)1441*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_4_os_8) {
1442*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1443*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1444*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1445*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1446*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1447*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_4_bw_4_is_8_os_8)1452*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_4_bw_4_is_8_os_8) {
1453*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1454*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1455*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1456*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1457*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1458*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1459*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1460*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1461*4bdc9457SAndroid Build Coastguard Worker }
1462*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_68_bw_76_ies_13)1463*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_68_bw_76_ies_13) {
1464*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1465*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
1466*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
1467*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
1468*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
1469*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1470*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
1471*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1472*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1473*4bdc9457SAndroid Build Coastguard Worker }
1474*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_12_bw_20_oes_13)1475*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_12_bw_20_oes_13) {
1476*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1477*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
1478*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
1479*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
1480*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
1481*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1482*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
1483*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1484*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1485*4bdc9457SAndroid Build Coastguard Worker }
1486*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2,bh_28_bw_92_ies_19_oes_15)1487*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_SCALAR_INT_2, bh_28_bw_92_ies_19_oes_15) {
1488*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1489*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
1490*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1491*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
1492*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
1493*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1494*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
1495*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1496*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1497*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_scalar_int);
1498*4bdc9457SAndroid Build Coastguard Worker }
1499*4bdc9457SAndroid Build Coastguard Worker
1500*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_8)1501*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_8) {
1502*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1503*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1504*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1505*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1506*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1507*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1508*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1509*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1511*4bdc9457SAndroid Build Coastguard Worker }
1512*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_1_8_bw_1_16)1513*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_1_8_bw_1_16) {
1514*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1515*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
1516*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
1517*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1518*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1519*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1520*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1521*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1522*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1525*4bdc9457SAndroid Build Coastguard Worker }
1526*4bdc9457SAndroid Build Coastguard Worker }
1527*4bdc9457SAndroid Build Coastguard Worker }
1528*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_16)1529*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_16) {
1530*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1531*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1532*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1533*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1534*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
1535*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1536*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1537*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1538*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1539*4bdc9457SAndroid Build Coastguard Worker }
1540*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_9_16)1541*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_9_16) {
1542*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1543*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1544*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1545*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1546*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1547*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1548*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1549*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1550*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1552*4bdc9457SAndroid Build Coastguard Worker }
1553*4bdc9457SAndroid Build Coastguard Worker }
1554*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_8_bw_9_16)1555*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_8_bw_9_16) {
1556*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1557*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1558*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1559*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1560*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1561*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1562*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1563*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1564*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1565*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1566*4bdc9457SAndroid Build Coastguard Worker }
1567*4bdc9457SAndroid Build Coastguard Worker }
1568*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_8_bw_8)1569*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_8_bw_8) {
1570*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1571*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1572*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1573*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1574*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1575*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1576*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1577*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1579*4bdc9457SAndroid Build Coastguard Worker }
1580*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_5_8_bw_8)1581*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_5_8_bw_8){
1582*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1583*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1584*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1585*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
1586*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1587*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
1588*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1589*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1590*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1591*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1592*4bdc9457SAndroid Build Coastguard Worker }
1593*4bdc9457SAndroid Build Coastguard Worker }
1594*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_5_8_bw_16)1595*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_5_8_bw_16){
1596*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1597*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1598*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1599*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1600*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1601*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
1602*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1603*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1604*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1606*4bdc9457SAndroid Build Coastguard Worker }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_5_8_bw_9_16)1609*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_5_8_bw_9_16) {
1610*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1611*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1612*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
1613*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1614*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1615*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1616*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1617*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1618*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1619*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1620*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1621*4bdc9457SAndroid Build Coastguard Worker }
1622*4bdc9457SAndroid Build Coastguard Worker }
1623*4bdc9457SAndroid Build Coastguard Worker }
1624*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_8_is_16)1625*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_8_is_16) {
1626*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1628*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1629*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1630*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1631*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1632*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1635*4bdc9457SAndroid Build Coastguard Worker }
1636*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_8_os_8)1637*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_8_os_8) {
1638*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1639*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1640*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1641*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1642*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1643*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1644*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1647*4bdc9457SAndroid Build Coastguard Worker }
1648*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_4_bw_8_is_16_os_8)1649*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_4_bw_8_is_16_os_8) {
1650*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1651*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1652*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1653*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1654*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1655*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1656*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1659*4bdc9457SAndroid Build Coastguard Worker }
1660*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_68_bw_152_ies_13)1661*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_68_bw_152_ies_13) {
1662*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1663*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1664*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
1665*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
1666*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
1667*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
1668*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1669*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
1670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1672*4bdc9457SAndroid Build Coastguard Worker }
1673*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_12_bw_40_oes_13)1674*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_12_bw_40_oes_13) {
1675*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1676*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1677*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
1678*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
1679*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
1680*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
1681*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1682*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
1683*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1684*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1685*4bdc9457SAndroid Build Coastguard Worker }
1686*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X8_SSE2_2,bh_28_bw_184_ies_19_oes_15)1687*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X8_SSE2_2, bh_28_bw_184_ies_19_oes_15) {
1688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1689*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1690*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
1691*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1692*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
1693*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
1694*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1695*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
1696*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x8_sse2);
1699*4bdc9457SAndroid Build Coastguard Worker }
1700*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1701*4bdc9457SAndroid Build Coastguard Worker
1702*4bdc9457SAndroid Build Coastguard Worker
1703*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_8)1704*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_8) {
1705*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1706*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1707*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1708*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1709*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1710*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1711*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1712*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1714*4bdc9457SAndroid Build Coastguard Worker }
1715*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_1_16_bw_1_16)1716*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_1_16_bw_1_16) {
1717*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1718*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
1719*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
1720*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1721*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1722*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1723*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1724*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1725*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1726*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1728*4bdc9457SAndroid Build Coastguard Worker }
1729*4bdc9457SAndroid Build Coastguard Worker }
1730*4bdc9457SAndroid Build Coastguard Worker }
1731*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_16)1732*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_16) {
1733*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1734*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1735*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1736*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1737*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
1738*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1739*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1740*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1741*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1742*4bdc9457SAndroid Build Coastguard Worker }
1743*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_9_16)1744*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_9_16) {
1745*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1746*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1747*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1748*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1749*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1750*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1751*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1752*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1753*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1754*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1755*4bdc9457SAndroid Build Coastguard Worker }
1756*4bdc9457SAndroid Build Coastguard Worker }
1757*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_16_bw_9_16)1758*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_16_bw_9_16) {
1759*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1760*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1762*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1763*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1764*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1765*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
1766*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1769*4bdc9457SAndroid Build Coastguard Worker }
1770*4bdc9457SAndroid Build Coastguard Worker }
1771*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_16_bw_8)1772*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_16_bw_8) {
1773*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1774*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1775*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1776*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
1777*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1778*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
1779*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1782*4bdc9457SAndroid Build Coastguard Worker }
1783*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_9_16_bw_8)1784*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_9_16_bw_8){
1785*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1786*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1787*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1788*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
1789*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1790*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
1791*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1792*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1795*4bdc9457SAndroid Build Coastguard Worker }
1796*4bdc9457SAndroid Build Coastguard Worker }
1797*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_9_16_bw_16)1798*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_9_16_bw_16){
1799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1800*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1801*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1802*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1803*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1804*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
1805*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1806*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1807*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1809*4bdc9457SAndroid Build Coastguard Worker }
1810*4bdc9457SAndroid Build Coastguard Worker }
1811*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_9_16_bw_9_16)1812*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_9_16_bw_9_16) {
1813*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1814*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1815*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
1816*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1817*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
1818*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1819*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1820*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1821*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1822*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1823*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1824*4bdc9457SAndroid Build Coastguard Worker }
1825*4bdc9457SAndroid Build Coastguard Worker }
1826*4bdc9457SAndroid Build Coastguard Worker }
1827*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_8_is_16)1828*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_8_is_16) {
1829*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1830*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1831*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1832*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1833*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1834*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1835*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1836*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1838*4bdc9457SAndroid Build Coastguard Worker }
1839*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_8_os_16)1840*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_8_os_16) {
1841*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1842*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1843*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1844*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1845*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1846*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1847*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1848*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1849*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1850*4bdc9457SAndroid Build Coastguard Worker }
1851*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_8_bw_8_is_16_os_16)1852*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_8_bw_8_is_16_os_16) {
1853*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1854*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1855*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1856*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1857*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1858*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1859*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1860*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1861*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1862*4bdc9457SAndroid Build Coastguard Worker }
1863*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_136_bw_152_ies_13)1864*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_136_bw_152_ies_13) {
1865*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1866*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1867*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
1868*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
1869*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
1870*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
1871*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1872*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
1873*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1874*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1875*4bdc9457SAndroid Build Coastguard Worker }
1876*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_24_bw_40_oes_13)1877*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_24_bw_40_oes_13) {
1878*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1879*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1880*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
1881*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
1882*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
1883*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
1884*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1885*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
1886*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1888*4bdc9457SAndroid Build Coastguard Worker }
1889*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2,bh_56_bw_184_ies_19_oes_15)1890*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_SSE2_2, bh_56_bw_184_ies_19_oes_15) {
1891*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1892*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1893*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
1894*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
1895*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
1896*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
1897*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1898*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
1899*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
1900*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_sse2);
1902*4bdc9457SAndroid Build Coastguard Worker }
1903*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1904*4bdc9457SAndroid Build Coastguard Worker
1905*4bdc9457SAndroid Build Coastguard Worker
1906*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_8)1907*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_8) {
1908*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1910*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1911*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1912*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1913*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1914*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1917*4bdc9457SAndroid Build Coastguard Worker }
1918*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_1_16_bw_1_16)1919*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_1_16_bw_1_16) {
1920*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1921*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
1922*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
1923*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1924*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
1925*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
1926*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
1927*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1928*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1929*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1930*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1931*4bdc9457SAndroid Build Coastguard Worker }
1932*4bdc9457SAndroid Build Coastguard Worker }
1933*4bdc9457SAndroid Build Coastguard Worker }
1934*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_16)1935*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_16) {
1936*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1937*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1938*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
1939*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1940*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
1941*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1942*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1943*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1944*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1945*4bdc9457SAndroid Build Coastguard Worker }
1946*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_9_16)1947*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_9_16) {
1948*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1949*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1950*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1951*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1952*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1953*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1954*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1955*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1956*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1957*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1958*4bdc9457SAndroid Build Coastguard Worker }
1959*4bdc9457SAndroid Build Coastguard Worker }
1960*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_16_bw_9_16)1961*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_16_bw_9_16) {
1962*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1963*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1964*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1965*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1966*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1967*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1968*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
1969*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1970*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1971*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1972*4bdc9457SAndroid Build Coastguard Worker }
1973*4bdc9457SAndroid Build Coastguard Worker }
1974*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_16_bw_8)1975*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_16_bw_8) {
1976*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1977*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1978*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1979*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
1980*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1981*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
1982*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1983*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1984*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1985*4bdc9457SAndroid Build Coastguard Worker }
1986*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_9_16_bw_8)1987*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_9_16_bw_8){
1988*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1989*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
1990*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1991*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
1992*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1993*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
1994*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1995*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
1996*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1997*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
1998*4bdc9457SAndroid Build Coastguard Worker }
1999*4bdc9457SAndroid Build Coastguard Worker }
2000*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_9_16_bw_16)2001*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_9_16_bw_16){
2002*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2003*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2004*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2005*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2006*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2007*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2008*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2009*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2010*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2012*4bdc9457SAndroid Build Coastguard Worker }
2013*4bdc9457SAndroid Build Coastguard Worker }
2014*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_9_16_bw_9_16)2015*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_9_16_bw_9_16) {
2016*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2017*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2018*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
2019*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2020*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2021*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2022*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2023*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2024*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2025*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2026*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2027*4bdc9457SAndroid Build Coastguard Worker }
2028*4bdc9457SAndroid Build Coastguard Worker }
2029*4bdc9457SAndroid Build Coastguard Worker }
2030*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_8_is_16)2031*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_8_is_16) {
2032*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2033*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2034*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2035*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2036*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2037*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2038*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2039*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2041*4bdc9457SAndroid Build Coastguard Worker }
2042*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_8_os_16)2043*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_8_os_16) {
2044*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2045*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2046*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2047*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2048*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2049*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2050*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2053*4bdc9457SAndroid Build Coastguard Worker }
2054*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_8_bw_8_is_16_os_16)2055*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_8_bw_8_is_16_os_16) {
2056*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2057*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2058*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2059*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2060*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2061*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2062*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2063*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2065*4bdc9457SAndroid Build Coastguard Worker }
2066*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_136_bw_152_ies_13)2067*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_136_bw_152_ies_13) {
2068*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2069*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2070*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
2071*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
2072*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
2073*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
2074*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2075*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
2076*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2077*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2078*4bdc9457SAndroid Build Coastguard Worker }
2079*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_24_bw_40_oes_13)2080*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_24_bw_40_oes_13) {
2081*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2082*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2083*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
2084*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
2085*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
2086*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
2087*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2088*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
2089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2091*4bdc9457SAndroid Build Coastguard Worker }
2092*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2,bh_56_bw_184_ies_19_oes_15)2093*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_SSE2_2, bh_56_bw_184_ies_19_oes_15) {
2094*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2095*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2096*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
2097*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
2098*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
2099*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
2100*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2101*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
2102*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2103*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_sse2);
2105*4bdc9457SAndroid Build Coastguard Worker }
2106*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2107*4bdc9457SAndroid Build Coastguard Worker
2108*4bdc9457SAndroid Build Coastguard Worker
2109*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_8)2110*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_8) {
2111*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2112*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2113*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2114*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2115*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2116*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2117*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2118*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2119*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2120*4bdc9457SAndroid Build Coastguard Worker }
2121*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_1_16_bw_1_16)2122*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_1_16_bw_1_16) {
2123*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2124*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
2125*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
2126*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2127*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2128*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2129*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2130*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2131*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2132*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2133*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2134*4bdc9457SAndroid Build Coastguard Worker }
2135*4bdc9457SAndroid Build Coastguard Worker }
2136*4bdc9457SAndroid Build Coastguard Worker }
2137*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_16)2138*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_16) {
2139*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2140*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2141*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2142*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2143*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2144*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2145*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2146*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2147*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2148*4bdc9457SAndroid Build Coastguard Worker }
2149*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_9_16)2150*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_9_16) {
2151*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2152*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2153*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2154*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2155*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2156*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2157*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2158*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2159*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2160*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2161*4bdc9457SAndroid Build Coastguard Worker }
2162*4bdc9457SAndroid Build Coastguard Worker }
2163*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_16_bw_9_16)2164*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_16_bw_9_16) {
2165*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2166*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2167*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2168*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2169*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2170*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2171*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2172*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2173*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2174*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2175*4bdc9457SAndroid Build Coastguard Worker }
2176*4bdc9457SAndroid Build Coastguard Worker }
2177*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_16_bw_8)2178*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_16_bw_8) {
2179*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2180*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2181*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2182*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
2183*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2184*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2185*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2186*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2187*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2188*4bdc9457SAndroid Build Coastguard Worker }
2189*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_9_16_bw_8)2190*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_9_16_bw_8){
2191*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2192*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2193*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2194*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
2195*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2196*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
2197*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2198*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2199*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2200*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2201*4bdc9457SAndroid Build Coastguard Worker }
2202*4bdc9457SAndroid Build Coastguard Worker }
2203*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_9_16_bw_16)2204*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_9_16_bw_16){
2205*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2206*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2207*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2208*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2209*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2210*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2211*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2212*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2213*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2214*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2215*4bdc9457SAndroid Build Coastguard Worker }
2216*4bdc9457SAndroid Build Coastguard Worker }
2217*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_9_16_bw_9_16)2218*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_9_16_bw_9_16) {
2219*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2220*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2221*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
2222*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2223*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2224*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2225*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2226*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2227*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2228*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2229*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2230*4bdc9457SAndroid Build Coastguard Worker }
2231*4bdc9457SAndroid Build Coastguard Worker }
2232*4bdc9457SAndroid Build Coastguard Worker }
2233*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_8_is_16)2234*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_8_is_16) {
2235*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2236*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2237*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2238*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2239*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2240*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2241*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2242*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2243*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2244*4bdc9457SAndroid Build Coastguard Worker }
2245*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_8_os_16)2246*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_8_os_16) {
2247*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2248*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2249*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2250*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2251*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2252*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2253*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2254*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2255*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2256*4bdc9457SAndroid Build Coastguard Worker }
2257*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_8_bw_8_is_16_os_16)2258*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_8_bw_8_is_16_os_16) {
2259*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2260*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2261*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2262*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2263*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2264*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2265*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2266*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2267*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2268*4bdc9457SAndroid Build Coastguard Worker }
2269*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_136_bw_152_ies_13)2270*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_136_bw_152_ies_13) {
2271*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2272*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2273*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
2274*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
2275*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
2276*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
2277*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2278*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
2279*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2280*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2281*4bdc9457SAndroid Build Coastguard Worker }
2282*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_24_bw_40_oes_13)2283*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_24_bw_40_oes_13) {
2284*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2285*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2286*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
2287*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
2288*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
2289*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
2290*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2291*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
2292*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2293*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2294*4bdc9457SAndroid Build Coastguard Worker }
2295*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2,bh_56_bw_184_ies_19_oes_15)2296*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_SSE2_2, bh_56_bw_184_ies_19_oes_15) {
2297*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2298*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2299*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
2300*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
2301*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
2302*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
2303*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2304*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
2305*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2306*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2307*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_sse2);
2308*4bdc9457SAndroid Build Coastguard Worker }
2309*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2310*4bdc9457SAndroid Build Coastguard Worker
2311*4bdc9457SAndroid Build Coastguard Worker
2312*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_8)2313*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_8) {
2314*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2315*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2316*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2317*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2318*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2319*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2320*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2321*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2322*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2323*4bdc9457SAndroid Build Coastguard Worker }
2324*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_1_16_bw_1_16)2325*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_1_16_bw_1_16) {
2326*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2327*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
2328*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
2329*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2330*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2331*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2332*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2333*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2334*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2337*4bdc9457SAndroid Build Coastguard Worker }
2338*4bdc9457SAndroid Build Coastguard Worker }
2339*4bdc9457SAndroid Build Coastguard Worker }
2340*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_16)2341*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_16) {
2342*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2343*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2344*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2345*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2346*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2347*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2348*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2351*4bdc9457SAndroid Build Coastguard Worker }
2352*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_9_16)2353*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_9_16) {
2354*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2355*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2356*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2357*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2358*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2359*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2360*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2361*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2362*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2363*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2364*4bdc9457SAndroid Build Coastguard Worker }
2365*4bdc9457SAndroid Build Coastguard Worker }
2366*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_16_bw_9_16)2367*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_16_bw_9_16) {
2368*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2369*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2370*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2371*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2372*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2373*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2374*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2375*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2376*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2377*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2378*4bdc9457SAndroid Build Coastguard Worker }
2379*4bdc9457SAndroid Build Coastguard Worker }
2380*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_16_bw_8)2381*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_16_bw_8) {
2382*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2383*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2384*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2385*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
2386*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2387*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2388*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2389*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2390*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2391*4bdc9457SAndroid Build Coastguard Worker }
2392*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_9_16_bw_8)2393*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_9_16_bw_8){
2394*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2395*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2396*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2397*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
2398*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2399*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
2400*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2401*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2402*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2404*4bdc9457SAndroid Build Coastguard Worker }
2405*4bdc9457SAndroid Build Coastguard Worker }
2406*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_9_16_bw_16)2407*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_9_16_bw_16){
2408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2409*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2410*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2411*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2412*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2413*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2414*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2415*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2416*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2417*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2418*4bdc9457SAndroid Build Coastguard Worker }
2419*4bdc9457SAndroid Build Coastguard Worker }
2420*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_9_16_bw_9_16)2421*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_9_16_bw_9_16) {
2422*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2423*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2424*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
2425*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2426*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2427*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2428*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2429*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2430*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2431*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2432*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2433*4bdc9457SAndroid Build Coastguard Worker }
2434*4bdc9457SAndroid Build Coastguard Worker }
2435*4bdc9457SAndroid Build Coastguard Worker }
2436*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_8_is_16)2437*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_8_is_16) {
2438*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2439*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2440*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2441*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2442*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2443*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2444*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2445*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2446*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2447*4bdc9457SAndroid Build Coastguard Worker }
2448*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_8_os_16)2449*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_8_os_16) {
2450*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2451*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2452*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2453*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2454*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2455*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2456*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2457*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2459*4bdc9457SAndroid Build Coastguard Worker }
2460*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_8_bw_8_is_16_os_16)2461*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_8_bw_8_is_16_os_16) {
2462*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2463*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2464*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2465*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2466*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2467*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2468*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2469*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2470*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2471*4bdc9457SAndroid Build Coastguard Worker }
2472*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_136_bw_152_ies_13)2473*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_136_bw_152_ies_13) {
2474*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2475*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2476*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
2477*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
2478*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
2479*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
2480*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2481*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
2482*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2483*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2484*4bdc9457SAndroid Build Coastguard Worker }
2485*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_24_bw_40_oes_13)2486*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_24_bw_40_oes_13) {
2487*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2488*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2489*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
2490*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
2491*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
2492*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
2493*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2494*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
2495*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2496*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2497*4bdc9457SAndroid Build Coastguard Worker }
2498*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2,bh_56_bw_184_ies_19_oes_15)2499*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_SSE2_2, bh_56_bw_184_ies_19_oes_15) {
2500*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2501*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2502*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
2503*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
2504*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
2505*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
2506*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2507*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
2508*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2509*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_sse2);
2511*4bdc9457SAndroid Build Coastguard Worker }
2512*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2513*4bdc9457SAndroid Build Coastguard Worker
2514*4bdc9457SAndroid Build Coastguard Worker
2515*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_8)2516*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_8) {
2517*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2518*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2519*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2520*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2521*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2522*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2523*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2524*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2525*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2526*4bdc9457SAndroid Build Coastguard Worker }
2527*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_1_16_bw_1_16)2528*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_1_16_bw_1_16) {
2529*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2530*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
2531*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
2532*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2533*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2534*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2535*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2536*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2537*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2538*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2539*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2540*4bdc9457SAndroid Build Coastguard Worker }
2541*4bdc9457SAndroid Build Coastguard Worker }
2542*4bdc9457SAndroid Build Coastguard Worker }
2543*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_16)2544*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_16) {
2545*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2546*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2547*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2548*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2549*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2550*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2551*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2552*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2553*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2554*4bdc9457SAndroid Build Coastguard Worker }
2555*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_9_16)2556*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_9_16) {
2557*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2558*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2559*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2560*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2561*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2562*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2563*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2564*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2565*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2566*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2567*4bdc9457SAndroid Build Coastguard Worker }
2568*4bdc9457SAndroid Build Coastguard Worker }
2569*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_16_bw_9_16)2570*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_16_bw_9_16) {
2571*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2572*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2573*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2574*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2575*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2576*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2577*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2578*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2579*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2580*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2581*4bdc9457SAndroid Build Coastguard Worker }
2582*4bdc9457SAndroid Build Coastguard Worker }
2583*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_16_bw_8)2584*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_16_bw_8) {
2585*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2586*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2587*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2588*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
2589*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2590*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2591*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2592*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2593*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2594*4bdc9457SAndroid Build Coastguard Worker }
2595*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_9_16_bw_8)2596*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_9_16_bw_8){
2597*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2598*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2599*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2600*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
2601*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2602*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
2603*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2604*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2605*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2606*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2607*4bdc9457SAndroid Build Coastguard Worker }
2608*4bdc9457SAndroid Build Coastguard Worker }
2609*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_9_16_bw_16)2610*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_9_16_bw_16){
2611*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2612*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2613*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2614*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2615*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2616*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2617*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2618*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2619*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2620*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2621*4bdc9457SAndroid Build Coastguard Worker }
2622*4bdc9457SAndroid Build Coastguard Worker }
2623*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_9_16_bw_9_16)2624*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_9_16_bw_9_16) {
2625*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2626*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2627*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
2628*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2629*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2630*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2631*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2632*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2633*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2634*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2635*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2636*4bdc9457SAndroid Build Coastguard Worker }
2637*4bdc9457SAndroid Build Coastguard Worker }
2638*4bdc9457SAndroid Build Coastguard Worker }
2639*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_8_is_16)2640*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_8_is_16) {
2641*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2642*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2643*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2644*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2645*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2646*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2647*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2648*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2649*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2650*4bdc9457SAndroid Build Coastguard Worker }
2651*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_8_os_16)2652*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_8_os_16) {
2653*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2654*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2655*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2656*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2657*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2658*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2659*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2660*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2661*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2662*4bdc9457SAndroid Build Coastguard Worker }
2663*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_8_bw_8_is_16_os_16)2664*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_8_bw_8_is_16_os_16) {
2665*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2666*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2667*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2668*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2669*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2670*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2671*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2672*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2673*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2674*4bdc9457SAndroid Build Coastguard Worker }
2675*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_136_bw_152_ies_13)2676*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_136_bw_152_ies_13) {
2677*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2678*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2679*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
2680*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
2681*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
2682*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
2683*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2684*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
2685*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2686*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2687*4bdc9457SAndroid Build Coastguard Worker }
2688*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_24_bw_40_oes_13)2689*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_24_bw_40_oes_13) {
2690*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2691*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2692*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
2693*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
2694*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
2695*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
2696*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2697*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
2698*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2699*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2700*4bdc9457SAndroid Build Coastguard Worker }
2701*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2,bh_56_bw_184_ies_19_oes_15)2702*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_SSE2_2, bh_56_bw_184_ies_19_oes_15) {
2703*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2704*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2705*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
2706*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
2707*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
2708*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
2709*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2710*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
2711*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2712*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_sse2);
2714*4bdc9457SAndroid Build Coastguard Worker }
2715*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2716*4bdc9457SAndroid Build Coastguard Worker
2717*4bdc9457SAndroid Build Coastguard Worker
2718*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_8)2719*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_8) {
2720*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2721*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2722*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2723*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2724*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2725*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2726*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2728*4bdc9457SAndroid Build Coastguard Worker }
2729*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_1_16_bw_1_16)2730*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_1_16_bw_1_16) {
2731*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
2732*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
2733*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2734*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2735*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2736*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2737*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2738*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2739*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2740*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2741*4bdc9457SAndroid Build Coastguard Worker }
2742*4bdc9457SAndroid Build Coastguard Worker }
2743*4bdc9457SAndroid Build Coastguard Worker }
2744*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_16)2745*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_16) {
2746*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2747*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2748*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2749*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2750*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2751*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2752*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2753*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2754*4bdc9457SAndroid Build Coastguard Worker }
2755*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_9_16)2756*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_9_16) {
2757*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2758*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2759*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2760*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2761*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2762*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2763*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2764*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2765*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2766*4bdc9457SAndroid Build Coastguard Worker }
2767*4bdc9457SAndroid Build Coastguard Worker }
2768*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_16_bw_9_16)2769*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_16_bw_9_16) {
2770*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2771*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2772*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2773*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2774*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2775*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2776*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2777*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2778*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2779*4bdc9457SAndroid Build Coastguard Worker }
2780*4bdc9457SAndroid Build Coastguard Worker }
2781*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_16_bw_8)2782*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_16_bw_8) {
2783*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2784*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2785*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
2786*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2787*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2788*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2789*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2790*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2791*4bdc9457SAndroid Build Coastguard Worker }
2792*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_9_16_bw_8)2793*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_9_16_bw_8){
2794*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2795*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2796*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
2797*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2798*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
2799*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2800*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2801*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2802*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2803*4bdc9457SAndroid Build Coastguard Worker }
2804*4bdc9457SAndroid Build Coastguard Worker }
2805*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_9_16_bw_16)2806*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_9_16_bw_16){
2807*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2808*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2809*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2810*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2811*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2812*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2813*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2814*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2815*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2816*4bdc9457SAndroid Build Coastguard Worker }
2817*4bdc9457SAndroid Build Coastguard Worker }
2818*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_9_16_bw_9_16)2819*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_9_16_bw_9_16) {
2820*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2821*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
2822*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2823*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
2824*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2825*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2826*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2827*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2828*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2829*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2830*4bdc9457SAndroid Build Coastguard Worker }
2831*4bdc9457SAndroid Build Coastguard Worker }
2832*4bdc9457SAndroid Build Coastguard Worker }
2833*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_8_is_16)2834*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_8_is_16) {
2835*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2836*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2837*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2838*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2839*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2840*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2841*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2842*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2843*4bdc9457SAndroid Build Coastguard Worker }
2844*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_8_os_16)2845*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_8_os_16) {
2846*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2847*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2848*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2849*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2850*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2851*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2852*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2853*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2854*4bdc9457SAndroid Build Coastguard Worker }
2855*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_8_bw_8_is_16_os_16)2856*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_8_bw_8_is_16_os_16) {
2857*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2858*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2859*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2860*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2861*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2862*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2863*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2864*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2865*4bdc9457SAndroid Build Coastguard Worker }
2866*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_136_bw_152_ies_13)2867*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_136_bw_152_ies_13) {
2868*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2869*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
2870*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
2871*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
2872*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
2873*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2874*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
2875*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2876*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2877*4bdc9457SAndroid Build Coastguard Worker }
2878*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_24_bw_40_oes_13)2879*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_24_bw_40_oes_13) {
2880*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2881*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
2882*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
2883*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
2884*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
2885*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2886*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
2887*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2888*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2889*4bdc9457SAndroid Build Coastguard Worker }
2890*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2,bh_56_bw_184_ies_19_oes_15)2891*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_WASMSIMD_2, bh_56_bw_184_ies_19_oes_15) {
2892*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2893*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
2894*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
2895*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
2896*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
2897*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2898*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
2899*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
2900*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_wasmsimd);
2902*4bdc9457SAndroid Build Coastguard Worker }
2903*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2904*4bdc9457SAndroid Build Coastguard Worker
2905*4bdc9457SAndroid Build Coastguard Worker
2906*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_8)2907*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_8) {
2908*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2909*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2910*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2911*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2912*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2913*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2914*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2915*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2916*4bdc9457SAndroid Build Coastguard Worker }
2917*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_1_16_bw_1_16)2918*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_1_16_bw_1_16) {
2919*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
2920*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
2921*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2922*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
2923*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
2924*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
2925*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2926*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2927*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2928*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2929*4bdc9457SAndroid Build Coastguard Worker }
2930*4bdc9457SAndroid Build Coastguard Worker }
2931*4bdc9457SAndroid Build Coastguard Worker }
2932*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_16)2933*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_16) {
2934*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2935*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2936*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2937*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
2938*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2939*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2940*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2941*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2942*4bdc9457SAndroid Build Coastguard Worker }
2943*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_9_16)2944*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_9_16) {
2945*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2946*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2947*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2948*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2949*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2950*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
2951*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2952*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2953*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2954*4bdc9457SAndroid Build Coastguard Worker }
2955*4bdc9457SAndroid Build Coastguard Worker }
2956*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_16_bw_9_16)2957*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_16_bw_9_16) {
2958*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2959*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2960*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
2961*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
2962*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
2963*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2964*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2965*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2967*4bdc9457SAndroid Build Coastguard Worker }
2968*4bdc9457SAndroid Build Coastguard Worker }
2969*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_16_bw_8)2970*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_16_bw_8) {
2971*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2972*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2973*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
2974*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2975*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
2976*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2977*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2978*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2979*4bdc9457SAndroid Build Coastguard Worker }
2980*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_9_16_bw_8)2981*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_9_16_bw_8){
2982*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2983*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2984*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
2985*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2986*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
2987*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2988*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
2989*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2990*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
2991*4bdc9457SAndroid Build Coastguard Worker }
2992*4bdc9457SAndroid Build Coastguard Worker }
2993*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_9_16_bw_16)2994*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_9_16_bw_16){
2995*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
2996*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2997*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
2998*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2999*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
3000*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3001*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3002*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3003*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3004*4bdc9457SAndroid Build Coastguard Worker }
3005*4bdc9457SAndroid Build Coastguard Worker }
3006*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_9_16_bw_9_16)3007*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_9_16_bw_9_16) {
3008*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3009*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
3010*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3011*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3012*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3013*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3014*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3015*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3016*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3017*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3018*4bdc9457SAndroid Build Coastguard Worker }
3019*4bdc9457SAndroid Build Coastguard Worker }
3020*4bdc9457SAndroid Build Coastguard Worker }
3021*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_8_is_16)3022*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_8_is_16) {
3023*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3024*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3025*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3026*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3027*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3028*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3029*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3030*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3031*4bdc9457SAndroid Build Coastguard Worker }
3032*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_8_os_16)3033*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_8_os_16) {
3034*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3035*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3036*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3037*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3038*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3039*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3040*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3042*4bdc9457SAndroid Build Coastguard Worker }
3043*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_8_bw_8_is_16_os_16)3044*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_8_bw_8_is_16_os_16) {
3045*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3046*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3047*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3048*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3049*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3050*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3053*4bdc9457SAndroid Build Coastguard Worker }
3054*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_136_bw_152_ies_13)3055*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_136_bw_152_ies_13) {
3056*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3057*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
3058*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
3059*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
3060*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
3061*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3062*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
3063*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3065*4bdc9457SAndroid Build Coastguard Worker }
3066*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_24_bw_40_oes_13)3067*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_24_bw_40_oes_13) {
3068*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3069*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
3070*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
3071*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
3072*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
3073*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3074*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
3075*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3076*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3077*4bdc9457SAndroid Build Coastguard Worker }
3078*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2,bh_56_bw_184_ies_19_oes_15)3079*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_WASMSIMD_2, bh_56_bw_184_ies_19_oes_15) {
3080*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3081*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
3082*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
3083*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
3084*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
3085*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3086*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
3087*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3088*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3089*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_wasmsimd);
3090*4bdc9457SAndroid Build Coastguard Worker }
3091*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3092*4bdc9457SAndroid Build Coastguard Worker
3093*4bdc9457SAndroid Build Coastguard Worker
3094*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_8)3095*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_8) {
3096*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3097*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3098*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3099*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3100*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3101*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3102*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3103*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3104*4bdc9457SAndroid Build Coastguard Worker }
3105*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_1_16_bw_1_16)3106*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_1_16_bw_1_16) {
3107*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
3108*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
3109*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3110*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3111*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3112*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3113*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3114*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3115*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3116*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3117*4bdc9457SAndroid Build Coastguard Worker }
3118*4bdc9457SAndroid Build Coastguard Worker }
3119*4bdc9457SAndroid Build Coastguard Worker }
3120*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_16)3121*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_16) {
3122*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3123*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3124*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3125*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
3126*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3127*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3128*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3129*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3130*4bdc9457SAndroid Build Coastguard Worker }
3131*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_9_16)3132*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_9_16) {
3133*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3134*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3135*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3136*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3137*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3138*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3139*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3140*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3141*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3142*4bdc9457SAndroid Build Coastguard Worker }
3143*4bdc9457SAndroid Build Coastguard Worker }
3144*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_16_bw_9_16)3145*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_16_bw_9_16) {
3146*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3147*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3148*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3149*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3150*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3151*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
3152*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3153*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3155*4bdc9457SAndroid Build Coastguard Worker }
3156*4bdc9457SAndroid Build Coastguard Worker }
3157*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_16_bw_8)3158*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_16_bw_8) {
3159*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3160*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3161*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
3162*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3163*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
3164*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3165*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3166*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3167*4bdc9457SAndroid Build Coastguard Worker }
3168*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_9_16_bw_8)3169*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_9_16_bw_8){
3170*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3171*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3172*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
3173*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3174*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
3175*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3176*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3177*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3178*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3179*4bdc9457SAndroid Build Coastguard Worker }
3180*4bdc9457SAndroid Build Coastguard Worker }
3181*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_9_16_bw_16)3182*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_9_16_bw_16){
3183*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3184*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3185*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3186*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3187*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
3188*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3189*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3190*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3191*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3192*4bdc9457SAndroid Build Coastguard Worker }
3193*4bdc9457SAndroid Build Coastguard Worker }
3194*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_9_16_bw_9_16)3195*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_9_16_bw_9_16) {
3196*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3197*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
3198*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3199*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3200*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3201*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3202*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3203*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3204*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3205*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3206*4bdc9457SAndroid Build Coastguard Worker }
3207*4bdc9457SAndroid Build Coastguard Worker }
3208*4bdc9457SAndroid Build Coastguard Worker }
3209*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_8_is_16)3210*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_8_is_16) {
3211*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3212*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3213*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3214*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3215*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3216*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3217*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3218*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3219*4bdc9457SAndroid Build Coastguard Worker }
3220*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_8_os_16)3221*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_8_os_16) {
3222*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3223*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3224*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3225*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3226*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3227*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3228*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3229*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3230*4bdc9457SAndroid Build Coastguard Worker }
3231*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_8_bw_8_is_16_os_16)3232*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_8_bw_8_is_16_os_16) {
3233*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3234*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3235*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3236*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3237*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3238*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3241*4bdc9457SAndroid Build Coastguard Worker }
3242*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_136_bw_152_ies_13)3243*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_136_bw_152_ies_13) {
3244*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3245*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
3246*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
3247*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
3248*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
3249*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3250*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
3251*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3252*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3253*4bdc9457SAndroid Build Coastguard Worker }
3254*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_24_bw_40_oes_13)3255*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_24_bw_40_oes_13) {
3256*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3257*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
3258*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
3259*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
3260*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
3261*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3262*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
3263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3265*4bdc9457SAndroid Build Coastguard Worker }
3266*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2,bh_56_bw_184_ies_19_oes_15)3267*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_WASMSIMD_2, bh_56_bw_184_ies_19_oes_15) {
3268*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3269*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
3270*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
3271*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
3272*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
3273*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3274*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
3275*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3276*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3277*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_wasmsimd);
3278*4bdc9457SAndroid Build Coastguard Worker }
3279*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3280*4bdc9457SAndroid Build Coastguard Worker
3281*4bdc9457SAndroid Build Coastguard Worker
3282*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_8)3283*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_8) {
3284*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3285*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3286*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3287*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3288*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3289*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3290*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3291*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3292*4bdc9457SAndroid Build Coastguard Worker }
3293*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_1_16_bw_1_16)3294*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_1_16_bw_1_16) {
3295*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
3296*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
3297*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3298*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3299*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3300*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3301*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3302*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3303*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3304*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3305*4bdc9457SAndroid Build Coastguard Worker }
3306*4bdc9457SAndroid Build Coastguard Worker }
3307*4bdc9457SAndroid Build Coastguard Worker }
3308*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_16)3309*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_16) {
3310*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3311*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3312*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3313*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
3314*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3315*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3316*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3317*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3318*4bdc9457SAndroid Build Coastguard Worker }
3319*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_9_16)3320*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_9_16) {
3321*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3322*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3323*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3324*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3325*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3326*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3327*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3328*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3329*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3330*4bdc9457SAndroid Build Coastguard Worker }
3331*4bdc9457SAndroid Build Coastguard Worker }
3332*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_16_bw_9_16)3333*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_16_bw_9_16) {
3334*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3335*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3336*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3337*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3338*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3339*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
3340*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3341*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3342*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3343*4bdc9457SAndroid Build Coastguard Worker }
3344*4bdc9457SAndroid Build Coastguard Worker }
3345*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_16_bw_8)3346*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_16_bw_8) {
3347*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3348*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3349*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
3350*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3351*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
3352*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3353*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3354*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3355*4bdc9457SAndroid Build Coastguard Worker }
3356*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_9_16_bw_8)3357*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_9_16_bw_8){
3358*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3359*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3360*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
3361*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3362*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
3363*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3364*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3365*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3366*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3367*4bdc9457SAndroid Build Coastguard Worker }
3368*4bdc9457SAndroid Build Coastguard Worker }
3369*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_9_16_bw_16)3370*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_9_16_bw_16){
3371*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3372*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3373*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3374*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3375*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
3376*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3377*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3378*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3379*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3380*4bdc9457SAndroid Build Coastguard Worker }
3381*4bdc9457SAndroid Build Coastguard Worker }
3382*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_9_16_bw_9_16)3383*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_9_16_bw_9_16) {
3384*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
3385*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
3386*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3387*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3388*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3389*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3390*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3391*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3392*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3393*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3394*4bdc9457SAndroid Build Coastguard Worker }
3395*4bdc9457SAndroid Build Coastguard Worker }
3396*4bdc9457SAndroid Build Coastguard Worker }
3397*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_8_is_16)3398*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_8_is_16) {
3399*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3400*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3401*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3402*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3403*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3404*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3405*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3406*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3407*4bdc9457SAndroid Build Coastguard Worker }
3408*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_8_os_16)3409*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_8_os_16) {
3410*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3411*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3412*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3413*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3414*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3415*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3416*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3417*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3418*4bdc9457SAndroid Build Coastguard Worker }
3419*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_8_bw_8_is_16_os_16)3420*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_8_bw_8_is_16_os_16) {
3421*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3422*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
3423*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3424*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3425*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3426*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3427*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3428*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3429*4bdc9457SAndroid Build Coastguard Worker }
3430*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_136_bw_152_ies_13)3431*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_136_bw_152_ies_13) {
3432*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3433*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
3434*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
3435*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
3436*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
3437*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3438*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
3439*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3441*4bdc9457SAndroid Build Coastguard Worker }
3442*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_24_bw_40_oes_13)3443*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_24_bw_40_oes_13) {
3444*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3445*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
3446*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
3447*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
3448*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
3449*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3450*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
3451*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3452*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3453*4bdc9457SAndroid Build Coastguard Worker }
3454*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2,bh_56_bw_184_ies_19_oes_15)3455*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_WASMSIMD_2, bh_56_bw_184_ies_19_oes_15) {
3456*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3457*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
3458*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
3459*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
3460*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
3461*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3462*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
3463*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3464*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3465*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_wasmsimd);
3466*4bdc9457SAndroid Build Coastguard Worker }
3467*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3468*4bdc9457SAndroid Build Coastguard Worker
3469*4bdc9457SAndroid Build Coastguard Worker
3470*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_4)3471*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_4) {
3472*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3473*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3474*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3475*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3476*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3477*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3478*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3479*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3480*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3481*4bdc9457SAndroid Build Coastguard Worker }
3482*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_1_8_bw_1_8)3483*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_1_8_bw_1_8) {
3484*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3485*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3486*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3487*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3488*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3489*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3490*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3491*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3492*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3493*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3494*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3495*4bdc9457SAndroid Build Coastguard Worker }
3496*4bdc9457SAndroid Build Coastguard Worker }
3497*4bdc9457SAndroid Build Coastguard Worker }
3498*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_8)3499*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_8) {
3500*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3501*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3502*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3503*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3504*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3505*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3506*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3507*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3508*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3509*4bdc9457SAndroid Build Coastguard Worker }
3510*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_5_8)3511*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_5_8) {
3512*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3513*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3514*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3515*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3516*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3517*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3518*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3519*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3520*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3521*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3522*4bdc9457SAndroid Build Coastguard Worker }
3523*4bdc9457SAndroid Build Coastguard Worker }
3524*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_8_bw_5_8)3525*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_8_bw_5_8) {
3526*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3527*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3528*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3529*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3530*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3531*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3532*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3533*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3536*4bdc9457SAndroid Build Coastguard Worker }
3537*4bdc9457SAndroid Build Coastguard Worker }
3538*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_8_bw_4)3539*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_8_bw_4) {
3540*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3541*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3542*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3543*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3544*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3545*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3546*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3547*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3548*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3549*4bdc9457SAndroid Build Coastguard Worker }
3550*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_5_8_bw_4)3551*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_5_8_bw_4){
3552*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3553*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3554*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3555*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3556*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3557*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3558*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3559*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3560*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3561*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3562*4bdc9457SAndroid Build Coastguard Worker }
3563*4bdc9457SAndroid Build Coastguard Worker }
3564*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_5_8_bw_8)3565*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_5_8_bw_8){
3566*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3567*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3568*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3569*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3570*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3571*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3572*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3573*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3574*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3575*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3576*4bdc9457SAndroid Build Coastguard Worker }
3577*4bdc9457SAndroid Build Coastguard Worker }
3578*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_5_8_bw_5_8)3579*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_5_8_bw_5_8) {
3580*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3581*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3582*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3583*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3584*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3585*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3586*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3587*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3588*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3589*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3590*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3591*4bdc9457SAndroid Build Coastguard Worker }
3592*4bdc9457SAndroid Build Coastguard Worker }
3593*4bdc9457SAndroid Build Coastguard Worker }
3594*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_4_is_8)3595*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_4_is_8) {
3596*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3597*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3598*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3599*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3600*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3601*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3602*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3603*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3604*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3605*4bdc9457SAndroid Build Coastguard Worker }
3606*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_4_os_8)3607*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_4_os_8) {
3608*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3609*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3610*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3611*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3612*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3613*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3614*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3615*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3616*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3617*4bdc9457SAndroid Build Coastguard Worker }
3618*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)3619*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
3620*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3621*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3622*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3623*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3624*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3625*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3626*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3627*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3628*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3629*4bdc9457SAndroid Build Coastguard Worker }
3630*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_68_bw_76_ies_13)3631*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_68_bw_76_ies_13) {
3632*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3633*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3634*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3635*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3636*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3637*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3638*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3639*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
3640*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3641*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3642*4bdc9457SAndroid Build Coastguard Worker }
3643*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_12_bw_20_oes_13)3644*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_12_bw_20_oes_13) {
3645*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3646*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3647*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3648*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3649*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3650*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3651*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3652*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
3653*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3654*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3655*4bdc9457SAndroid Build Coastguard Worker }
3656*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)3657*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_DEC_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
3658*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3659*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3660*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3661*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3662*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3663*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3664*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3665*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
3666*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3667*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3668*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_dec_zip_neon);
3669*4bdc9457SAndroid Build Coastguard Worker }
3670*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
3671*4bdc9457SAndroid Build Coastguard Worker
3672*4bdc9457SAndroid Build Coastguard Worker
3673*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_4)3674*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_4) {
3675*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3676*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3677*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3678*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3679*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3680*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3681*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3682*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3683*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3684*4bdc9457SAndroid Build Coastguard Worker }
3685*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_1_8_bw_1_8)3686*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_1_8_bw_1_8) {
3687*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3688*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3689*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3690*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3691*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3692*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3693*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3694*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3695*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3696*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3697*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3698*4bdc9457SAndroid Build Coastguard Worker }
3699*4bdc9457SAndroid Build Coastguard Worker }
3700*4bdc9457SAndroid Build Coastguard Worker }
3701*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_8)3702*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_8) {
3703*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3704*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3705*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3706*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3707*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3708*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3709*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3710*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3711*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3712*4bdc9457SAndroid Build Coastguard Worker }
3713*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_5_8)3714*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_5_8) {
3715*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3716*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3717*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3718*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3719*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3720*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3721*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3722*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3723*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3724*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3725*4bdc9457SAndroid Build Coastguard Worker }
3726*4bdc9457SAndroid Build Coastguard Worker }
3727*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_8_bw_5_8)3728*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_8_bw_5_8) {
3729*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3730*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3731*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3732*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3733*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3734*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3735*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3736*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3737*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3738*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3739*4bdc9457SAndroid Build Coastguard Worker }
3740*4bdc9457SAndroid Build Coastguard Worker }
3741*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_8_bw_4)3742*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_8_bw_4) {
3743*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3744*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3745*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3746*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3747*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3748*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3749*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3750*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3751*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3752*4bdc9457SAndroid Build Coastguard Worker }
3753*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_5_8_bw_4)3754*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_5_8_bw_4){
3755*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3756*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3757*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3758*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3759*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3760*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3761*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3762*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3763*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3764*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3765*4bdc9457SAndroid Build Coastguard Worker }
3766*4bdc9457SAndroid Build Coastguard Worker }
3767*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_5_8_bw_8)3768*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_5_8_bw_8){
3769*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3770*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3771*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3772*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3773*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3774*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3775*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3776*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3777*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3778*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3779*4bdc9457SAndroid Build Coastguard Worker }
3780*4bdc9457SAndroid Build Coastguard Worker }
3781*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_5_8_bw_5_8)3782*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_5_8_bw_5_8) {
3783*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3784*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3785*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3786*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3787*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3788*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3789*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3790*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3791*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3792*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3793*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3794*4bdc9457SAndroid Build Coastguard Worker }
3795*4bdc9457SAndroid Build Coastguard Worker }
3796*4bdc9457SAndroid Build Coastguard Worker }
3797*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_4_is_8)3798*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_4_is_8) {
3799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3800*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3801*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3802*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3803*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3804*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3805*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3806*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3807*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3808*4bdc9457SAndroid Build Coastguard Worker }
3809*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_4_os_8)3810*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_4_os_8) {
3811*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3812*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3813*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3814*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3815*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3816*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3817*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3818*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3820*4bdc9457SAndroid Build Coastguard Worker }
3821*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)3822*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
3823*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3824*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3825*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3826*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3827*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3828*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3829*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3830*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3831*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3832*4bdc9457SAndroid Build Coastguard Worker }
3833*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_68_bw_76_ies_13)3834*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_68_bw_76_ies_13) {
3835*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3836*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3837*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
3838*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
3839*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
3840*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
3841*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3842*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
3843*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3844*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3845*4bdc9457SAndroid Build Coastguard Worker }
3846*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_12_bw_20_oes_13)3847*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_12_bw_20_oes_13) {
3848*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3849*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3850*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
3851*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
3852*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
3853*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
3854*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3855*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
3856*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3857*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3858*4bdc9457SAndroid Build Coastguard Worker }
3859*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)3860*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MOV_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
3861*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3862*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3863*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
3864*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
3865*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
3866*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
3867*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3868*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
3869*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
3870*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3871*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_mov_zip_neon);
3872*4bdc9457SAndroid Build Coastguard Worker }
3873*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
3874*4bdc9457SAndroid Build Coastguard Worker
3875*4bdc9457SAndroid Build Coastguard Worker
3876*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_4)3877*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_4) {
3878*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3879*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3880*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3881*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3882*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3883*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3884*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3885*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3886*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3887*4bdc9457SAndroid Build Coastguard Worker }
3888*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_1_8_bw_1_8)3889*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_1_8_bw_1_8) {
3890*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3891*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
3892*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
3893*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3894*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
3895*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
3896*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3897*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3898*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3899*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3900*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3901*4bdc9457SAndroid Build Coastguard Worker }
3902*4bdc9457SAndroid Build Coastguard Worker }
3903*4bdc9457SAndroid Build Coastguard Worker }
3904*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_8)3905*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_8) {
3906*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3907*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3908*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3909*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
3910*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3911*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3912*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3913*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3914*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3915*4bdc9457SAndroid Build Coastguard Worker }
3916*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_5_8)3917*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_5_8) {
3918*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3919*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3920*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3921*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3922*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3923*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3924*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
3925*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3926*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3927*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3928*4bdc9457SAndroid Build Coastguard Worker }
3929*4bdc9457SAndroid Build Coastguard Worker }
3930*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_8_bw_5_8)3931*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_8_bw_5_8) {
3932*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3933*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3934*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3935*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
3936*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
3937*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
3938*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3939*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3940*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3941*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3942*4bdc9457SAndroid Build Coastguard Worker }
3943*4bdc9457SAndroid Build Coastguard Worker }
3944*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_8_bw_4)3945*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_8_bw_4) {
3946*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3947*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3948*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
3949*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
3950*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
3951*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
3952*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3953*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3954*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3955*4bdc9457SAndroid Build Coastguard Worker }
3956*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_5_8_bw_4)3957*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_5_8_bw_4){
3958*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3959*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3960*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3961*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
3962*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3963*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
3964*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3965*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3966*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3967*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3968*4bdc9457SAndroid Build Coastguard Worker }
3969*4bdc9457SAndroid Build Coastguard Worker }
3970*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_5_8_bw_8)3971*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_5_8_bw_8){
3972*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3973*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3974*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3975*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
3976*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3977*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
3978*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3979*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3980*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3981*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3982*4bdc9457SAndroid Build Coastguard Worker }
3983*4bdc9457SAndroid Build Coastguard Worker }
3984*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_5_8_bw_5_8)3985*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_5_8_bw_5_8) {
3986*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
3987*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
3988*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
3989*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
3990*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
3991*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
3992*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
3993*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
3994*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
3995*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
3996*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
3997*4bdc9457SAndroid Build Coastguard Worker }
3998*4bdc9457SAndroid Build Coastguard Worker }
3999*4bdc9457SAndroid Build Coastguard Worker }
4000*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_4_is_8)4001*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_4_is_8) {
4002*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4003*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4004*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4005*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4006*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4007*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4008*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4009*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4010*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4011*4bdc9457SAndroid Build Coastguard Worker }
4012*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_4_os_8)4013*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_4_os_8) {
4014*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4015*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4016*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4017*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4018*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4019*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4020*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4021*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4022*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4023*4bdc9457SAndroid Build Coastguard Worker }
4024*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)4025*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
4026*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4027*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4028*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4029*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4030*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4031*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4032*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4033*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4034*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4035*4bdc9457SAndroid Build Coastguard Worker }
4036*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_68_bw_76_ies_13)4037*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_68_bw_76_ies_13) {
4038*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4039*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4040*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4041*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4042*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4043*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4044*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4045*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
4046*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4047*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4048*4bdc9457SAndroid Build Coastguard Worker }
4049*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_12_bw_20_oes_13)4050*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_12_bw_20_oes_13) {
4051*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4052*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4053*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4054*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4055*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4056*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4057*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4058*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
4059*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4060*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4061*4bdc9457SAndroid Build Coastguard Worker }
4062*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)4063*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_MULTI_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
4064*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4065*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4066*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4067*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4068*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4069*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4070*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4071*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
4072*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4073*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4074*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_multi_zip_neon);
4075*4bdc9457SAndroid Build Coastguard Worker }
4076*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4077*4bdc9457SAndroid Build Coastguard Worker
4078*4bdc9457SAndroid Build Coastguard Worker
4079*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_4)4080*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_4) {
4081*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4082*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4083*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4084*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4085*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4086*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4087*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4088*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4089*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4090*4bdc9457SAndroid Build Coastguard Worker }
4091*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_1_8_bw_1_8)4092*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_1_8_bw_1_8) {
4093*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4094*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4095*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4096*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4097*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4098*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4099*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4100*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4101*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4102*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4103*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4104*4bdc9457SAndroid Build Coastguard Worker }
4105*4bdc9457SAndroid Build Coastguard Worker }
4106*4bdc9457SAndroid Build Coastguard Worker }
4107*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_8)4108*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_8) {
4109*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4110*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4111*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4112*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4113*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4114*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4115*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4116*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4117*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4118*4bdc9457SAndroid Build Coastguard Worker }
4119*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_5_8)4120*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_5_8) {
4121*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4122*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4123*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4124*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4125*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4126*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4127*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4128*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4129*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4130*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4131*4bdc9457SAndroid Build Coastguard Worker }
4132*4bdc9457SAndroid Build Coastguard Worker }
4133*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_5_8)4134*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_5_8) {
4135*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4136*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4137*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4138*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4139*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4140*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4141*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4142*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4143*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4144*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4145*4bdc9457SAndroid Build Coastguard Worker }
4146*4bdc9457SAndroid Build Coastguard Worker }
4147*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_4)4148*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_4) {
4149*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4150*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4151*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4152*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4153*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4154*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4155*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4156*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4157*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4158*4bdc9457SAndroid Build Coastguard Worker }
4159*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_5_8_bw_4)4160*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_5_8_bw_4){
4161*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4162*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4163*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4164*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4165*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4166*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4167*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4168*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4169*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4170*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4171*4bdc9457SAndroid Build Coastguard Worker }
4172*4bdc9457SAndroid Build Coastguard Worker }
4173*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_5_8_bw_8)4174*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_5_8_bw_8){
4175*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4176*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4177*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4178*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4179*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4180*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4181*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4182*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4183*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4184*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4185*4bdc9457SAndroid Build Coastguard Worker }
4186*4bdc9457SAndroid Build Coastguard Worker }
4187*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_5_8_bw_5_8)4188*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_5_8_bw_5_8) {
4189*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4190*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4191*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4192*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4193*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4194*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4195*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4196*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4197*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4198*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4199*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4200*4bdc9457SAndroid Build Coastguard Worker }
4201*4bdc9457SAndroid Build Coastguard Worker }
4202*4bdc9457SAndroid Build Coastguard Worker }
4203*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_4_is_8)4204*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_4_is_8) {
4205*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4206*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4207*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4208*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4209*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4210*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4211*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4214*4bdc9457SAndroid Build Coastguard Worker }
4215*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_4_os_8)4216*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_4_os_8) {
4217*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4218*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4219*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4220*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4221*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4222*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4223*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4224*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4225*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4226*4bdc9457SAndroid Build Coastguard Worker }
4227*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)4228*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
4229*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4230*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4231*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4232*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4233*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4234*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4235*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4236*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4237*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4238*4bdc9457SAndroid Build Coastguard Worker }
4239*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_68_bw_76_ies_13)4240*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_68_bw_76_ies_13) {
4241*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4242*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4243*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4244*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4245*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4246*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4247*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4248*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
4249*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4250*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4251*4bdc9457SAndroid Build Coastguard Worker }
4252*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_12_bw_20_oes_13)4253*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_12_bw_20_oes_13) {
4254*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4255*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4256*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4257*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4258*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4259*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4260*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4261*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
4262*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4263*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4264*4bdc9457SAndroid Build Coastguard Worker }
4265*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)4266*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_MULTI_SWITCH_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
4267*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4268*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4269*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4270*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4271*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4272*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4273*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4274*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
4275*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4276*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4277*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_multi_switch_zip_neon);
4278*4bdc9457SAndroid Build Coastguard Worker }
4279*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4280*4bdc9457SAndroid Build Coastguard Worker
4281*4bdc9457SAndroid Build Coastguard Worker
4282*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_4)4283*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_4) {
4284*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4285*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4286*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4287*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4288*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4289*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4290*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4291*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4292*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4293*4bdc9457SAndroid Build Coastguard Worker }
4294*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_1_8_bw_1_8)4295*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_1_8_bw_1_8) {
4296*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4297*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4298*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4299*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4300*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4301*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4302*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4303*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4304*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4305*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4306*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4307*4bdc9457SAndroid Build Coastguard Worker }
4308*4bdc9457SAndroid Build Coastguard Worker }
4309*4bdc9457SAndroid Build Coastguard Worker }
4310*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_8)4311*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_8) {
4312*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4313*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4314*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4315*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4316*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4317*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4318*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4319*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4320*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4321*4bdc9457SAndroid Build Coastguard Worker }
4322*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_5_8)4323*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_5_8) {
4324*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4325*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4326*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4327*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4328*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4329*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4330*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4331*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4332*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4333*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4334*4bdc9457SAndroid Build Coastguard Worker }
4335*4bdc9457SAndroid Build Coastguard Worker }
4336*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_8_bw_5_8)4337*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_8_bw_5_8) {
4338*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4339*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4340*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4341*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4342*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4343*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4344*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4345*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4346*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4347*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4348*4bdc9457SAndroid Build Coastguard Worker }
4349*4bdc9457SAndroid Build Coastguard Worker }
4350*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_8_bw_4)4351*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_8_bw_4) {
4352*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4353*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4354*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4355*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4356*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4357*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4358*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4359*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4360*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4361*4bdc9457SAndroid Build Coastguard Worker }
4362*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_5_8_bw_4)4363*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_5_8_bw_4){
4364*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4365*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4366*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4367*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4368*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4369*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4370*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4371*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4372*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4373*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4374*4bdc9457SAndroid Build Coastguard Worker }
4375*4bdc9457SAndroid Build Coastguard Worker }
4376*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_5_8_bw_8)4377*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_5_8_bw_8){
4378*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4379*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4380*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4381*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4382*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4383*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4384*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4385*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4386*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4387*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4388*4bdc9457SAndroid Build Coastguard Worker }
4389*4bdc9457SAndroid Build Coastguard Worker }
4390*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_5_8_bw_5_8)4391*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_5_8_bw_5_8) {
4392*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4393*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4394*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4395*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4396*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4397*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4398*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4399*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4400*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4401*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4402*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4403*4bdc9457SAndroid Build Coastguard Worker }
4404*4bdc9457SAndroid Build Coastguard Worker }
4405*4bdc9457SAndroid Build Coastguard Worker }
4406*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_4_is_8)4407*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_4_is_8) {
4408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4409*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4410*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4411*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4412*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4413*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4414*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4415*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4416*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4417*4bdc9457SAndroid Build Coastguard Worker }
4418*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_4_os_8)4419*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_4_os_8) {
4420*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4421*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4422*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4423*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4424*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4425*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4426*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4427*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4428*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4429*4bdc9457SAndroid Build Coastguard Worker }
4430*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)4431*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
4432*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4433*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4434*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4435*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4436*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4437*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4438*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4439*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4441*4bdc9457SAndroid Build Coastguard Worker }
4442*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_68_bw_76_ies_13)4443*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_68_bw_76_ies_13) {
4444*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4445*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4446*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4447*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4448*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4449*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4450*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4451*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
4452*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4453*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4454*4bdc9457SAndroid Build Coastguard Worker }
4455*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_12_bw_20_oes_13)4456*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_12_bw_20_oes_13) {
4457*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4458*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4459*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4460*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4461*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4462*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4463*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4464*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
4465*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4466*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4467*4bdc9457SAndroid Build Coastguard Worker }
4468*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)4469*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_DEC_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
4470*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4471*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4472*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4473*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4474*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4475*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4476*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4477*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
4478*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4479*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4480*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_dec_zip_neon);
4481*4bdc9457SAndroid Build Coastguard Worker }
4482*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4483*4bdc9457SAndroid Build Coastguard Worker
4484*4bdc9457SAndroid Build Coastguard Worker
4485*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_4)4486*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_4) {
4487*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4488*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4489*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4490*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4491*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4492*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4493*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4494*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4496*4bdc9457SAndroid Build Coastguard Worker }
4497*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_1_8_bw_1_8)4498*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_1_8_bw_1_8) {
4499*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4500*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4501*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4502*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4503*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4504*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4505*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4506*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4507*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4508*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4509*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4510*4bdc9457SAndroid Build Coastguard Worker }
4511*4bdc9457SAndroid Build Coastguard Worker }
4512*4bdc9457SAndroid Build Coastguard Worker }
4513*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_8)4514*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_8) {
4515*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4516*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4517*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4518*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4519*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4520*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4521*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4522*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4523*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4524*4bdc9457SAndroid Build Coastguard Worker }
4525*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_5_8)4526*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_5_8) {
4527*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4528*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4529*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4530*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4531*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4532*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4533*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4534*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4535*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4536*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4537*4bdc9457SAndroid Build Coastguard Worker }
4538*4bdc9457SAndroid Build Coastguard Worker }
4539*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_8_bw_5_8)4540*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_8_bw_5_8) {
4541*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4542*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4543*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4544*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4545*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4546*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4547*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4548*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4549*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4550*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4551*4bdc9457SAndroid Build Coastguard Worker }
4552*4bdc9457SAndroid Build Coastguard Worker }
4553*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_8_bw_4)4554*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_8_bw_4) {
4555*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4556*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4557*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4558*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4559*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4560*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4561*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4562*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4563*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4564*4bdc9457SAndroid Build Coastguard Worker }
4565*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_5_8_bw_4)4566*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_5_8_bw_4){
4567*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4568*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4569*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4570*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4571*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4572*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4573*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4574*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4575*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4576*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4577*4bdc9457SAndroid Build Coastguard Worker }
4578*4bdc9457SAndroid Build Coastguard Worker }
4579*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_5_8_bw_8)4580*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_5_8_bw_8){
4581*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4582*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4583*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4584*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4585*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4586*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4587*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4588*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4589*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4590*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4591*4bdc9457SAndroid Build Coastguard Worker }
4592*4bdc9457SAndroid Build Coastguard Worker }
4593*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_5_8_bw_5_8)4594*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_5_8_bw_5_8) {
4595*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4596*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4597*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4598*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4599*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4600*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4601*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4602*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4603*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4604*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4606*4bdc9457SAndroid Build Coastguard Worker }
4607*4bdc9457SAndroid Build Coastguard Worker }
4608*4bdc9457SAndroid Build Coastguard Worker }
4609*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_4_is_8)4610*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_4_is_8) {
4611*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4612*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4613*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4614*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4615*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4616*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4617*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4618*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4619*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4620*4bdc9457SAndroid Build Coastguard Worker }
4621*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_4_os_8)4622*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_4_os_8) {
4623*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4624*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4625*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4626*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4627*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4628*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4629*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4630*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4631*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4632*4bdc9457SAndroid Build Coastguard Worker }
4633*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)4634*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
4635*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4636*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4637*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4638*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4639*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4640*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4641*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4642*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4643*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4644*4bdc9457SAndroid Build Coastguard Worker }
4645*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_68_bw_76_ies_13)4646*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_68_bw_76_ies_13) {
4647*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4648*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4649*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4650*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4651*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4652*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4653*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4654*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
4655*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4656*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4657*4bdc9457SAndroid Build Coastguard Worker }
4658*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_12_bw_20_oes_13)4659*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_12_bw_20_oes_13) {
4660*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4661*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4662*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4663*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4664*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4665*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4666*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4667*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
4668*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4669*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4670*4bdc9457SAndroid Build Coastguard Worker }
4671*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)4672*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MOV_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
4673*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4674*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4675*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4676*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4677*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4678*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4679*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4680*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
4681*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4682*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4683*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_mov_zip_neon);
4684*4bdc9457SAndroid Build Coastguard Worker }
4685*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4686*4bdc9457SAndroid Build Coastguard Worker
4687*4bdc9457SAndroid Build Coastguard Worker
4688*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_4)4689*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_4) {
4690*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4691*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4692*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4693*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4694*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4695*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4696*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4699*4bdc9457SAndroid Build Coastguard Worker }
4700*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_1_8_bw_1_8)4701*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_1_8_bw_1_8) {
4702*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4703*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4704*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4705*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4706*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4707*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4708*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4709*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4710*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4711*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4712*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4713*4bdc9457SAndroid Build Coastguard Worker }
4714*4bdc9457SAndroid Build Coastguard Worker }
4715*4bdc9457SAndroid Build Coastguard Worker }
4716*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_8)4717*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_8) {
4718*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4719*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4720*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4721*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4722*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4723*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4724*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4725*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4726*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4727*4bdc9457SAndroid Build Coastguard Worker }
4728*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_5_8)4729*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_5_8) {
4730*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4731*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4732*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4733*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4734*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4735*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4736*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4737*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4738*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4739*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4740*4bdc9457SAndroid Build Coastguard Worker }
4741*4bdc9457SAndroid Build Coastguard Worker }
4742*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_5_8)4743*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_5_8) {
4744*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4745*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4746*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4747*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4748*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4749*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4750*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4751*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4752*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4753*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4754*4bdc9457SAndroid Build Coastguard Worker }
4755*4bdc9457SAndroid Build Coastguard Worker }
4756*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_4)4757*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_4) {
4758*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4759*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4760*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4761*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4762*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4763*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4764*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4765*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4766*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4767*4bdc9457SAndroid Build Coastguard Worker }
4768*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_5_8_bw_4)4769*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_5_8_bw_4){
4770*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4771*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4772*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4773*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4774*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4775*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4776*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4777*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4778*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4779*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4780*4bdc9457SAndroid Build Coastguard Worker }
4781*4bdc9457SAndroid Build Coastguard Worker }
4782*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_5_8_bw_8)4783*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_5_8_bw_8){
4784*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4785*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4786*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4787*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4788*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4789*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4790*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4791*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4792*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4793*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4794*4bdc9457SAndroid Build Coastguard Worker }
4795*4bdc9457SAndroid Build Coastguard Worker }
4796*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_5_8_bw_5_8)4797*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_5_8_bw_5_8) {
4798*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4799*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4800*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
4801*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4802*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
4803*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4804*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4805*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4806*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4807*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4809*4bdc9457SAndroid Build Coastguard Worker }
4810*4bdc9457SAndroid Build Coastguard Worker }
4811*4bdc9457SAndroid Build Coastguard Worker }
4812*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_4_is_8)4813*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_4_is_8) {
4814*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4815*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4816*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4817*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4818*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4819*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4820*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4821*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4822*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4823*4bdc9457SAndroid Build Coastguard Worker }
4824*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_4_os_8)4825*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_4_os_8) {
4826*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4827*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4828*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4829*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4830*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4831*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4832*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4833*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4834*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4835*4bdc9457SAndroid Build Coastguard Worker }
4836*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)4837*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
4838*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4839*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4840*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4841*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4842*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4843*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4844*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4845*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4846*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4847*4bdc9457SAndroid Build Coastguard Worker }
4848*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_68_bw_76_ies_13)4849*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_68_bw_76_ies_13) {
4850*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4851*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4852*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
4853*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
4854*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
4855*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
4856*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4857*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
4858*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4859*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4860*4bdc9457SAndroid Build Coastguard Worker }
4861*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_12_bw_20_oes_13)4862*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_12_bw_20_oes_13) {
4863*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4864*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4865*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
4866*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
4867*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
4868*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
4869*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4870*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
4871*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4872*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4873*4bdc9457SAndroid Build Coastguard Worker }
4874*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)4875*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_MULTI_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
4876*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4877*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4878*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
4879*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
4880*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
4881*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
4882*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4883*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
4884*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
4885*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4886*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_multi_zip_neon);
4887*4bdc9457SAndroid Build Coastguard Worker }
4888*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
4889*4bdc9457SAndroid Build Coastguard Worker
4890*4bdc9457SAndroid Build Coastguard Worker
4891*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_4)4892*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_4) {
4893*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4894*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4895*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4896*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4897*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4898*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4899*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4900*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4902*4bdc9457SAndroid Build Coastguard Worker }
4903*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_1_8_bw_1_8)4904*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_1_8_bw_1_8) {
4905*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4906*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
4907*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++j){
4908*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4909*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
4910*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
4911*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
4912*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4913*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4914*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4915*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4916*4bdc9457SAndroid Build Coastguard Worker }
4917*4bdc9457SAndroid Build Coastguard Worker }
4918*4bdc9457SAndroid Build Coastguard Worker }
4919*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_8)4920*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_8) {
4921*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4922*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4923*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4924*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
4925*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4926*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4927*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4930*4bdc9457SAndroid Build Coastguard Worker }
4931*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_5_8)4932*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_5_8) {
4933*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4934*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4935*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4936*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4937*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4938*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4939*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
4940*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4941*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4942*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4943*4bdc9457SAndroid Build Coastguard Worker }
4944*4bdc9457SAndroid Build Coastguard Worker }
4945*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_5_8)4946*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_5_8) {
4947*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4948*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4949*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4950*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
4951*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
4952*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
4953*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4954*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4955*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4956*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4957*4bdc9457SAndroid Build Coastguard Worker }
4958*4bdc9457SAndroid Build Coastguard Worker }
4959*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_4)4960*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_4) {
4961*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4962*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4963*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
4964*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
4965*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
4966*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
4967*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4968*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4969*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4970*4bdc9457SAndroid Build Coastguard Worker }
4971*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_5_8_bw_4)4972*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_5_8_bw_4){
4973*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4974*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4975*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4976*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
4977*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4978*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
4979*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4980*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4981*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4982*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4983*4bdc9457SAndroid Build Coastguard Worker }
4984*4bdc9457SAndroid Build Coastguard Worker }
4985*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_5_8_bw_8)4986*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_5_8_bw_8){
4987*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
4988*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
4989*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
4990*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
4991*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
4992*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
4993*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
4994*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
4995*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
4996*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
4997*4bdc9457SAndroid Build Coastguard Worker }
4998*4bdc9457SAndroid Build Coastguard Worker }
4999*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_5_8_bw_5_8)5000*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_5_8_bw_5_8) {
5001*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5002*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
5003*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++j){
5004*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5005*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5006*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5007*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5008*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5009*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5010*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5012*4bdc9457SAndroid Build Coastguard Worker }
5013*4bdc9457SAndroid Build Coastguard Worker }
5014*4bdc9457SAndroid Build Coastguard Worker }
5015*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_4_is_8)5016*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_4_is_8) {
5017*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5018*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5019*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5020*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
5021*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5022*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5023*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5024*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5025*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5026*4bdc9457SAndroid Build Coastguard Worker }
5027*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_4_os_8)5028*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_4_os_8) {
5029*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5030*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5031*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
5032*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5033*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5034*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5035*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5036*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5037*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5038*4bdc9457SAndroid Build Coastguard Worker }
5039*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_4_bw_4_is_8_os_8)5040*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_4_bw_4_is_8_os_8) {
5041*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5042*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5043*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5044*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5045*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
5046*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
5047*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5048*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5049*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5050*4bdc9457SAndroid Build Coastguard Worker }
5051*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_68_bw_76_ies_13)5052*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_68_bw_76_ies_13) {
5053*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5054*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5055*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
5056*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
5057*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
5058*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
5059*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5060*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
5061*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5062*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5063*4bdc9457SAndroid Build Coastguard Worker }
5064*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_12_bw_20_oes_13)5065*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_12_bw_20_oes_13) {
5066*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5067*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5068*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
5069*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
5070*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
5071*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
5072*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5073*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
5074*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5075*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5076*4bdc9457SAndroid Build Coastguard Worker }
5077*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2,bh_28_bw_92_ies_19_oes_15)5078*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__4X4_REUSE_SWITCH_ZIP_NEON_2, bh_28_bw_92_ies_19_oes_15) {
5079*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5080*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5081*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
5082*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
5083*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
5084*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
5085*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5086*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
5087*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5088*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5089*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__4x4_reuse_switch_zip_neon);
5090*4bdc9457SAndroid Build Coastguard Worker }
5091*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5092*4bdc9457SAndroid Build Coastguard Worker
5093*4bdc9457SAndroid Build Coastguard Worker
5094*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_8)5095*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_8) {
5096*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5097*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5098*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5099*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5100*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5101*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5102*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5103*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5105*4bdc9457SAndroid Build Coastguard Worker }
5106*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_1_16_bw_1_16)5107*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_1_16_bw_1_16) {
5108*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5109*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
5110*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
5111*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5112*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5113*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5114*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5115*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5116*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5117*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5118*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5119*4bdc9457SAndroid Build Coastguard Worker }
5120*4bdc9457SAndroid Build Coastguard Worker }
5121*4bdc9457SAndroid Build Coastguard Worker }
5122*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_16)5123*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_16) {
5124*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5125*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5126*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5127*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5128*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5129*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5130*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5131*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5132*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5133*4bdc9457SAndroid Build Coastguard Worker }
5134*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_9_16)5135*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_9_16) {
5136*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5137*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5138*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5139*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5140*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5141*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5142*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5143*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5144*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5145*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5146*4bdc9457SAndroid Build Coastguard Worker }
5147*4bdc9457SAndroid Build Coastguard Worker }
5148*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_16_bw_9_16)5149*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_16_bw_9_16) {
5150*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5151*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5152*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5153*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5154*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5155*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5156*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5157*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5158*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5159*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5160*4bdc9457SAndroid Build Coastguard Worker }
5161*4bdc9457SAndroid Build Coastguard Worker }
5162*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_16_bw_8)5163*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_16_bw_8) {
5164*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5165*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5166*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5167*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
5168*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5169*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5170*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5171*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5172*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5173*4bdc9457SAndroid Build Coastguard Worker }
5174*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_9_16_bw_8)5175*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_9_16_bw_8){
5176*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5177*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5178*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5179*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
5180*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5181*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
5182*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5183*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5184*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5185*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5186*4bdc9457SAndroid Build Coastguard Worker }
5187*4bdc9457SAndroid Build Coastguard Worker }
5188*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_9_16_bw_16)5189*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_9_16_bw_16){
5190*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5191*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5192*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5193*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5194*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5195*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5196*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5197*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5198*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5199*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5200*4bdc9457SAndroid Build Coastguard Worker }
5201*4bdc9457SAndroid Build Coastguard Worker }
5202*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_9_16_bw_9_16)5203*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_9_16_bw_9_16) {
5204*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5205*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5206*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
5207*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5208*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5209*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5210*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5211*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5212*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5213*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5214*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5215*4bdc9457SAndroid Build Coastguard Worker }
5216*4bdc9457SAndroid Build Coastguard Worker }
5217*4bdc9457SAndroid Build Coastguard Worker }
5218*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_8_is_16)5219*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_8_is_16) {
5220*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5221*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5222*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5223*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5224*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5225*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5226*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5227*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5228*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5229*4bdc9457SAndroid Build Coastguard Worker }
5230*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_8_os_16)5231*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_8_os_16) {
5232*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5233*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5234*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5235*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5236*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5237*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5238*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5241*4bdc9457SAndroid Build Coastguard Worker }
5242*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)5243*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
5244*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5245*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5246*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5247*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5248*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5249*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5250*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5251*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5252*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5253*4bdc9457SAndroid Build Coastguard Worker }
5254*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_136_bw_152_ies_13)5255*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_136_bw_152_ies_13) {
5256*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5257*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5258*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
5259*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
5260*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
5261*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
5262*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5263*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
5264*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5265*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5266*4bdc9457SAndroid Build Coastguard Worker }
5267*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_24_bw_40_oes_13)5268*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_24_bw_40_oes_13) {
5269*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5270*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5271*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
5272*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
5273*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
5274*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
5275*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5276*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
5277*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5278*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5279*4bdc9457SAndroid Build Coastguard Worker }
5280*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)5281*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_DEC_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
5282*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5283*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5284*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
5285*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
5286*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
5287*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
5288*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5289*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
5290*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5291*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5292*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_dec_zip_neon);
5293*4bdc9457SAndroid Build Coastguard Worker }
5294*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5295*4bdc9457SAndroid Build Coastguard Worker
5296*4bdc9457SAndroid Build Coastguard Worker
5297*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_8)5298*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_8) {
5299*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5300*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5301*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5302*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5303*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5304*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5305*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5306*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5307*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5308*4bdc9457SAndroid Build Coastguard Worker }
5309*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_1_16_bw_1_16)5310*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_1_16_bw_1_16) {
5311*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5312*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
5313*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
5314*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5315*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5316*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5317*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5318*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5319*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5320*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5321*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5322*4bdc9457SAndroid Build Coastguard Worker }
5323*4bdc9457SAndroid Build Coastguard Worker }
5324*4bdc9457SAndroid Build Coastguard Worker }
5325*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_16)5326*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_16) {
5327*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5328*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5329*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5330*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5331*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5332*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5333*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5334*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5335*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5336*4bdc9457SAndroid Build Coastguard Worker }
5337*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_9_16)5338*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_9_16) {
5339*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5340*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5341*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5342*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5343*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5344*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5345*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5346*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5347*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5348*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5349*4bdc9457SAndroid Build Coastguard Worker }
5350*4bdc9457SAndroid Build Coastguard Worker }
5351*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_16_bw_9_16)5352*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_16_bw_9_16) {
5353*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5354*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5355*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5356*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5357*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5358*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5359*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5360*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5361*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5362*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5363*4bdc9457SAndroid Build Coastguard Worker }
5364*4bdc9457SAndroid Build Coastguard Worker }
5365*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_16_bw_8)5366*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_16_bw_8) {
5367*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5368*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5369*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5370*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
5371*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5372*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5373*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5374*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5375*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5376*4bdc9457SAndroid Build Coastguard Worker }
5377*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_9_16_bw_8)5378*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_9_16_bw_8){
5379*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5380*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5381*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5382*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
5383*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5384*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
5385*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5386*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5387*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5388*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5389*4bdc9457SAndroid Build Coastguard Worker }
5390*4bdc9457SAndroid Build Coastguard Worker }
5391*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_9_16_bw_16)5392*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_9_16_bw_16){
5393*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5394*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5395*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5396*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5397*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5398*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5399*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5400*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5401*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5402*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5403*4bdc9457SAndroid Build Coastguard Worker }
5404*4bdc9457SAndroid Build Coastguard Worker }
5405*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_9_16_bw_9_16)5406*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_9_16_bw_9_16) {
5407*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5408*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5409*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
5410*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5411*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5412*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5413*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5414*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5415*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5416*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5417*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5418*4bdc9457SAndroid Build Coastguard Worker }
5419*4bdc9457SAndroid Build Coastguard Worker }
5420*4bdc9457SAndroid Build Coastguard Worker }
5421*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_8_is_16)5422*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_8_is_16) {
5423*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5424*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5425*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5426*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5427*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5428*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5429*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5430*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5431*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5432*4bdc9457SAndroid Build Coastguard Worker }
5433*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_8_os_16)5434*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_8_os_16) {
5435*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5436*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5437*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5438*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5439*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5440*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5441*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5442*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5443*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5444*4bdc9457SAndroid Build Coastguard Worker }
5445*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)5446*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
5447*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5448*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5449*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5450*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5451*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5452*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5453*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5454*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5455*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5456*4bdc9457SAndroid Build Coastguard Worker }
5457*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_136_bw_152_ies_13)5458*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_136_bw_152_ies_13) {
5459*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5460*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5461*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
5462*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
5463*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
5464*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
5465*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5466*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
5467*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5468*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5469*4bdc9457SAndroid Build Coastguard Worker }
5470*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_24_bw_40_oes_13)5471*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_24_bw_40_oes_13) {
5472*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5473*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5474*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
5475*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
5476*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
5477*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
5478*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5479*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
5480*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5481*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5482*4bdc9457SAndroid Build Coastguard Worker }
5483*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)5484*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_MOV_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
5485*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5486*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5487*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
5488*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
5489*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
5490*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
5491*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5492*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
5493*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5494*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_mov_zip_neon);
5496*4bdc9457SAndroid Build Coastguard Worker }
5497*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5498*4bdc9457SAndroid Build Coastguard Worker
5499*4bdc9457SAndroid Build Coastguard Worker
5500*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_8)5501*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_8) {
5502*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5503*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5504*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5505*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5506*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5507*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5508*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5509*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5511*4bdc9457SAndroid Build Coastguard Worker }
5512*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_1_16_bw_1_16)5513*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_1_16_bw_1_16) {
5514*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5515*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
5516*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
5517*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5518*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5519*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5520*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5521*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5522*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5525*4bdc9457SAndroid Build Coastguard Worker }
5526*4bdc9457SAndroid Build Coastguard Worker }
5527*4bdc9457SAndroid Build Coastguard Worker }
5528*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_16)5529*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_16) {
5530*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5531*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5532*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5533*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5534*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5535*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5536*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5537*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5538*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5539*4bdc9457SAndroid Build Coastguard Worker }
5540*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_9_16)5541*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_9_16) {
5542*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5543*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5544*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5545*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5546*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5547*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5548*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5549*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5550*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5552*4bdc9457SAndroid Build Coastguard Worker }
5553*4bdc9457SAndroid Build Coastguard Worker }
5554*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_16_bw_9_16)5555*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_16_bw_9_16) {
5556*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5557*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5558*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5559*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5560*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5561*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5562*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5563*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5564*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5565*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5566*4bdc9457SAndroid Build Coastguard Worker }
5567*4bdc9457SAndroid Build Coastguard Worker }
5568*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_16_bw_8)5569*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_16_bw_8) {
5570*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5571*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5572*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5573*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
5574*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5575*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5576*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5577*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5579*4bdc9457SAndroid Build Coastguard Worker }
5580*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_9_16_bw_8)5581*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_9_16_bw_8){
5582*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5583*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5584*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5585*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
5586*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5587*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
5588*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5589*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5590*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5591*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5592*4bdc9457SAndroid Build Coastguard Worker }
5593*4bdc9457SAndroid Build Coastguard Worker }
5594*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_9_16_bw_16)5595*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_9_16_bw_16){
5596*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5597*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5598*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5599*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5600*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5601*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5602*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5603*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5604*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5606*4bdc9457SAndroid Build Coastguard Worker }
5607*4bdc9457SAndroid Build Coastguard Worker }
5608*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_9_16_bw_9_16)5609*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_9_16_bw_9_16) {
5610*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5611*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5612*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
5613*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5614*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5615*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5616*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5617*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5618*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5619*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5620*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5621*4bdc9457SAndroid Build Coastguard Worker }
5622*4bdc9457SAndroid Build Coastguard Worker }
5623*4bdc9457SAndroid Build Coastguard Worker }
5624*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_8_is_16)5625*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_8_is_16) {
5626*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5628*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5629*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5630*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5631*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5632*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5635*4bdc9457SAndroid Build Coastguard Worker }
5636*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_8_os_16)5637*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_8_os_16) {
5638*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5639*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5640*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5641*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5642*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5643*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5644*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5647*4bdc9457SAndroid Build Coastguard Worker }
5648*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)5649*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
5650*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5651*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5652*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5653*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5654*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5655*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5656*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5659*4bdc9457SAndroid Build Coastguard Worker }
5660*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_136_bw_152_ies_13)5661*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_136_bw_152_ies_13) {
5662*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5663*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5664*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
5665*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
5666*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
5667*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
5668*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5669*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
5670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5672*4bdc9457SAndroid Build Coastguard Worker }
5673*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_24_bw_40_oes_13)5674*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_24_bw_40_oes_13) {
5675*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5676*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5677*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
5678*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
5679*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
5680*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
5681*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5682*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
5683*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5684*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5685*4bdc9457SAndroid Build Coastguard Worker }
5686*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)5687*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_MULTI_SWITCH_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
5688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5689*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5690*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
5691*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
5692*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
5693*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
5694*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5695*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
5696*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_multi_switch_zip_neon);
5699*4bdc9457SAndroid Build Coastguard Worker }
5700*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5701*4bdc9457SAndroid Build Coastguard Worker
5702*4bdc9457SAndroid Build Coastguard Worker
5703*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_8)5704*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_8) {
5705*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5706*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5707*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5708*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5709*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5710*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5711*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5712*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5714*4bdc9457SAndroid Build Coastguard Worker }
5715*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_1_16_bw_1_16)5716*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_1_16_bw_1_16) {
5717*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5718*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
5719*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
5720*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5721*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5722*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5723*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5724*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5725*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5726*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5728*4bdc9457SAndroid Build Coastguard Worker }
5729*4bdc9457SAndroid Build Coastguard Worker }
5730*4bdc9457SAndroid Build Coastguard Worker }
5731*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_16)5732*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_16) {
5733*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5734*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5735*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5736*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5737*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5738*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5739*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5740*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5741*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5742*4bdc9457SAndroid Build Coastguard Worker }
5743*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_9_16)5744*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_9_16) {
5745*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5746*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5747*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5748*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5749*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5750*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5751*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5752*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5753*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5754*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5755*4bdc9457SAndroid Build Coastguard Worker }
5756*4bdc9457SAndroid Build Coastguard Worker }
5757*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_16_bw_9_16)5758*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_16_bw_9_16) {
5759*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5760*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5762*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5763*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5764*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5765*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5766*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5769*4bdc9457SAndroid Build Coastguard Worker }
5770*4bdc9457SAndroid Build Coastguard Worker }
5771*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_16_bw_8)5772*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_16_bw_8) {
5773*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5774*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5775*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5776*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
5777*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5778*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5779*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5782*4bdc9457SAndroid Build Coastguard Worker }
5783*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_9_16_bw_8)5784*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_9_16_bw_8){
5785*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5786*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5787*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5788*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
5789*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5790*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
5791*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5792*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5795*4bdc9457SAndroid Build Coastguard Worker }
5796*4bdc9457SAndroid Build Coastguard Worker }
5797*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_9_16_bw_16)5798*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_9_16_bw_16){
5799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5800*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5801*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5802*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5803*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5804*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5805*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5806*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5807*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5809*4bdc9457SAndroid Build Coastguard Worker }
5810*4bdc9457SAndroid Build Coastguard Worker }
5811*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_9_16_bw_9_16)5812*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_9_16_bw_9_16) {
5813*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5814*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5815*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
5816*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5817*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
5818*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5819*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5820*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5821*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5822*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5823*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5824*4bdc9457SAndroid Build Coastguard Worker }
5825*4bdc9457SAndroid Build Coastguard Worker }
5826*4bdc9457SAndroid Build Coastguard Worker }
5827*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_8_is_16)5828*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_8_is_16) {
5829*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5830*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5831*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5832*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5833*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5834*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5835*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5836*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5838*4bdc9457SAndroid Build Coastguard Worker }
5839*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_8_os_16)5840*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_8_os_16) {
5841*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5842*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5843*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5844*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5845*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5846*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5847*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5848*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5849*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5850*4bdc9457SAndroid Build Coastguard Worker }
5851*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)5852*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
5853*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5854*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5855*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5856*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5857*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5858*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5859*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5860*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5861*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5862*4bdc9457SAndroid Build Coastguard Worker }
5863*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_136_bw_152_ies_13)5864*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_136_bw_152_ies_13) {
5865*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5866*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5867*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
5868*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
5869*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
5870*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
5871*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5872*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
5873*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5874*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5875*4bdc9457SAndroid Build Coastguard Worker }
5876*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_24_bw_40_oes_13)5877*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_24_bw_40_oes_13) {
5878*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5879*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5880*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
5881*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
5882*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
5883*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
5884*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5885*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
5886*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5888*4bdc9457SAndroid Build Coastguard Worker }
5889*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)5890*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_DEC_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
5891*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5892*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5893*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
5894*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
5895*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
5896*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
5897*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5898*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
5899*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
5900*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_dec_zip_neon);
5902*4bdc9457SAndroid Build Coastguard Worker }
5903*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
5904*4bdc9457SAndroid Build Coastguard Worker
5905*4bdc9457SAndroid Build Coastguard Worker
5906*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_8)5907*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_8) {
5908*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5910*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5911*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5912*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5913*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5914*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5917*4bdc9457SAndroid Build Coastguard Worker }
5918*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_1_16_bw_1_16)5919*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_1_16_bw_1_16) {
5920*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5921*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
5922*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
5923*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5924*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
5925*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
5926*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
5927*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5928*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5929*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5930*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5931*4bdc9457SAndroid Build Coastguard Worker }
5932*4bdc9457SAndroid Build Coastguard Worker }
5933*4bdc9457SAndroid Build Coastguard Worker }
5934*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_16)5935*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_16) {
5936*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5937*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5938*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
5939*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
5940*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
5941*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5942*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5943*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5944*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5945*4bdc9457SAndroid Build Coastguard Worker }
5946*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_9_16)5947*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_9_16) {
5948*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5949*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5950*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5951*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5952*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5953*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5954*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
5955*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5956*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5957*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5958*4bdc9457SAndroid Build Coastguard Worker }
5959*4bdc9457SAndroid Build Coastguard Worker }
5960*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_16_bw_9_16)5961*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_16_bw_9_16) {
5962*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5963*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5964*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5965*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
5966*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
5967*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
5968*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5969*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5970*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5971*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5972*4bdc9457SAndroid Build Coastguard Worker }
5973*4bdc9457SAndroid Build Coastguard Worker }
5974*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_16_bw_8)5975*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_16_bw_8) {
5976*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5977*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5978*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
5979*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
5980*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
5981*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
5982*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5983*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5984*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5985*4bdc9457SAndroid Build Coastguard Worker }
5986*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_9_16_bw_8)5987*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_9_16_bw_8){
5988*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
5989*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
5990*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
5991*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
5992*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
5993*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
5994*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
5995*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
5996*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
5997*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
5998*4bdc9457SAndroid Build Coastguard Worker }
5999*4bdc9457SAndroid Build Coastguard Worker }
6000*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_9_16_bw_16)6001*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_9_16_bw_16){
6002*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6003*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6004*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6005*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6006*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6007*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
6008*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6009*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6010*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6012*4bdc9457SAndroid Build Coastguard Worker }
6013*4bdc9457SAndroid Build Coastguard Worker }
6014*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_9_16_bw_9_16)6015*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_9_16_bw_9_16) {
6016*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6017*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6018*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
6019*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6020*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6021*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6022*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6023*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6024*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6025*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6026*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6027*4bdc9457SAndroid Build Coastguard Worker }
6028*4bdc9457SAndroid Build Coastguard Worker }
6029*4bdc9457SAndroid Build Coastguard Worker }
6030*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_8_is_16)6031*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_8_is_16) {
6032*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6033*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6034*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6035*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
6036*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6037*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6038*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6039*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6041*4bdc9457SAndroid Build Coastguard Worker }
6042*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_8_os_16)6043*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_8_os_16) {
6044*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6045*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6046*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
6047*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6048*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6049*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6050*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6053*4bdc9457SAndroid Build Coastguard Worker }
6054*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)6055*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
6056*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6057*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6058*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6059*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6060*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6061*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6062*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6063*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6065*4bdc9457SAndroid Build Coastguard Worker }
6066*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_136_bw_152_ies_13)6067*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_136_bw_152_ies_13) {
6068*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6069*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6070*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
6071*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
6072*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
6073*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
6074*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6075*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
6076*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6077*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6078*4bdc9457SAndroid Build Coastguard Worker }
6079*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_24_bw_40_oes_13)6080*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_24_bw_40_oes_13) {
6081*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6082*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6083*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
6084*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
6085*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
6086*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
6087*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6088*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
6089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6091*4bdc9457SAndroid Build Coastguard Worker }
6092*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)6093*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MOV_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
6094*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6095*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6096*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
6097*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
6098*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
6099*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
6100*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6101*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
6102*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6103*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_mov_zip_neon);
6105*4bdc9457SAndroid Build Coastguard Worker }
6106*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6107*4bdc9457SAndroid Build Coastguard Worker
6108*4bdc9457SAndroid Build Coastguard Worker
6109*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_8)6110*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_8) {
6111*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6112*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6113*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6114*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6115*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6116*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6117*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6118*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6119*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6120*4bdc9457SAndroid Build Coastguard Worker }
6121*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_1_16_bw_1_16)6122*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_1_16_bw_1_16) {
6123*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6124*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
6125*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
6126*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6127*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6128*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6129*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6130*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6131*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6132*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6133*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6134*4bdc9457SAndroid Build Coastguard Worker }
6135*4bdc9457SAndroid Build Coastguard Worker }
6136*4bdc9457SAndroid Build Coastguard Worker }
6137*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_16)6138*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_16) {
6139*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6140*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6141*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6142*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
6143*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
6144*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6145*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6146*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6147*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6148*4bdc9457SAndroid Build Coastguard Worker }
6149*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_9_16)6150*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_9_16) {
6151*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6152*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6153*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6154*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6155*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6156*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6157*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6158*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6159*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6160*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6161*4bdc9457SAndroid Build Coastguard Worker }
6162*4bdc9457SAndroid Build Coastguard Worker }
6163*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_16_bw_9_16)6164*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_16_bw_9_16) {
6165*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6166*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6167*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6168*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6169*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6170*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6171*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
6172*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6173*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6174*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6175*4bdc9457SAndroid Build Coastguard Worker }
6176*4bdc9457SAndroid Build Coastguard Worker }
6177*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_16_bw_8)6178*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_16_bw_8) {
6179*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6180*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6181*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
6182*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
6183*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6184*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
6185*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6186*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6187*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6188*4bdc9457SAndroid Build Coastguard Worker }
6189*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_9_16_bw_8)6190*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_9_16_bw_8){
6191*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6192*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6193*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6194*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
6195*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6196*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
6197*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6198*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6199*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6200*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6201*4bdc9457SAndroid Build Coastguard Worker }
6202*4bdc9457SAndroid Build Coastguard Worker }
6203*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_9_16_bw_16)6204*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_9_16_bw_16){
6205*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6206*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6207*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6208*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6209*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6210*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
6211*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6212*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6213*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6214*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6215*4bdc9457SAndroid Build Coastguard Worker }
6216*4bdc9457SAndroid Build Coastguard Worker }
6217*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_9_16_bw_9_16)6218*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_9_16_bw_9_16) {
6219*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6220*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6221*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
6222*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6223*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6224*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6225*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6226*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6227*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6228*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6229*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6230*4bdc9457SAndroid Build Coastguard Worker }
6231*4bdc9457SAndroid Build Coastguard Worker }
6232*4bdc9457SAndroid Build Coastguard Worker }
6233*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_8_is_16)6234*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_8_is_16) {
6235*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6236*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6237*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6238*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
6239*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6240*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6241*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6242*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6243*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6244*4bdc9457SAndroid Build Coastguard Worker }
6245*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_8_os_16)6246*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_8_os_16) {
6247*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6248*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6249*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
6250*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6251*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6252*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6253*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6254*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6255*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6256*4bdc9457SAndroid Build Coastguard Worker }
6257*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)6258*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
6259*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6260*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6261*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6262*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6263*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6264*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6265*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6266*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6267*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6268*4bdc9457SAndroid Build Coastguard Worker }
6269*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_136_bw_152_ies_13)6270*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_136_bw_152_ies_13) {
6271*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6272*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6273*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
6274*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
6275*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
6276*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
6277*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6278*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
6279*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6280*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6281*4bdc9457SAndroid Build Coastguard Worker }
6282*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_24_bw_40_oes_13)6283*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_24_bw_40_oes_13) {
6284*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6285*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6286*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
6287*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
6288*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
6289*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
6290*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6291*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
6292*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6293*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6294*4bdc9457SAndroid Build Coastguard Worker }
6295*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)6296*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_MULTI_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
6297*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6298*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6299*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
6300*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
6301*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
6302*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
6303*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6304*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
6305*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6306*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6307*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_multi_zip_neon);
6308*4bdc9457SAndroid Build Coastguard Worker }
6309*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6310*4bdc9457SAndroid Build Coastguard Worker
6311*4bdc9457SAndroid Build Coastguard Worker
6312*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_8)6313*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_8) {
6314*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6315*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6316*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6317*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6318*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6319*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6320*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6321*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6322*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6323*4bdc9457SAndroid Build Coastguard Worker }
6324*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_1_16_bw_1_16)6325*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_1_16_bw_1_16) {
6326*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6327*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 16; ++i){
6328*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 16; ++j){
6329*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6330*4bdc9457SAndroid Build Coastguard Worker .input_stride(j * 3)
6331*4bdc9457SAndroid Build Coastguard Worker .output_stride(i * 7)
6332*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6333*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6334*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6337*4bdc9457SAndroid Build Coastguard Worker }
6338*4bdc9457SAndroid Build Coastguard Worker }
6339*4bdc9457SAndroid Build Coastguard Worker }
6340*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_16)6341*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_16) {
6342*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6343*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6344*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6345*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
6346*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
6347*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6348*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6351*4bdc9457SAndroid Build Coastguard Worker }
6352*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_9_16)6353*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_9_16) {
6354*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6355*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6356*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6357*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6358*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6359*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6360*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6361*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6362*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6363*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6364*4bdc9457SAndroid Build Coastguard Worker }
6365*4bdc9457SAndroid Build Coastguard Worker }
6366*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_16_bw_9_16)6367*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_16_bw_9_16) {
6368*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6369*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6370*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6371*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
6372*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6373*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
6374*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
6375*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6376*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6377*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6378*4bdc9457SAndroid Build Coastguard Worker }
6379*4bdc9457SAndroid Build Coastguard Worker }
6380*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_16_bw_8)6381*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_16_bw_8) {
6382*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6383*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6384*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
6385*4bdc9457SAndroid Build Coastguard Worker .output_stride(28)
6386*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6387*4bdc9457SAndroid Build Coastguard Worker .block_height(16)
6388*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6389*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6390*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6391*4bdc9457SAndroid Build Coastguard Worker }
6392*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_9_16_bw_8)6393*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_9_16_bw_8){
6394*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6395*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6396*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6397*4bdc9457SAndroid Build Coastguard Worker .input_stride(25)
6398*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6399*4bdc9457SAndroid Build Coastguard Worker .block_width(11)
6400*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6401*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6402*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6404*4bdc9457SAndroid Build Coastguard Worker }
6405*4bdc9457SAndroid Build Coastguard Worker }
6406*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_9_16_bw_16)6407*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_9_16_bw_16){
6408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6409*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6410*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6411*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6412*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6413*4bdc9457SAndroid Build Coastguard Worker .block_width(16)
6414*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6415*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6416*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6417*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6418*4bdc9457SAndroid Build Coastguard Worker }
6419*4bdc9457SAndroid Build Coastguard Worker }
6420*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_9_16_bw_9_16)6421*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_9_16_bw_9_16) {
6422*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6423*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 9; i < 16; ++i){
6424*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 9; j < 16; ++j){
6425*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6426*4bdc9457SAndroid Build Coastguard Worker .input_stride(j)
6427*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
6428*4bdc9457SAndroid Build Coastguard Worker .block_width(j)
6429*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
6430*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6431*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6432*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6433*4bdc9457SAndroid Build Coastguard Worker }
6434*4bdc9457SAndroid Build Coastguard Worker }
6435*4bdc9457SAndroid Build Coastguard Worker }
6436*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_8_is_16)6437*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_8_is_16) {
6438*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6439*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6440*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6441*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
6442*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6443*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6444*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6445*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6446*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6447*4bdc9457SAndroid Build Coastguard Worker }
6448*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_8_os_16)6449*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_8_os_16) {
6450*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6451*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6452*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
6453*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6454*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6455*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6456*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6457*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6459*4bdc9457SAndroid Build Coastguard Worker }
6460*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_8_bw_8_is_16_os_16)6461*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_8_bw_8_is_16_os_16) {
6462*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6463*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6464*4bdc9457SAndroid Build Coastguard Worker .input_stride(16)
6465*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
6466*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
6467*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
6468*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6469*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6470*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6471*4bdc9457SAndroid Build Coastguard Worker }
6472*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_136_bw_152_ies_13)6473*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_136_bw_152_ies_13) {
6474*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6475*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6476*4bdc9457SAndroid Build Coastguard Worker .input_stride(152)
6477*4bdc9457SAndroid Build Coastguard Worker .output_stride(136)
6478*4bdc9457SAndroid Build Coastguard Worker .block_width(152)
6479*4bdc9457SAndroid Build Coastguard Worker .block_height(136)
6480*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6481*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(13)
6482*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6483*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6484*4bdc9457SAndroid Build Coastguard Worker }
6485*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_24_bw_40_oes_13)6486*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_24_bw_40_oes_13) {
6487*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6488*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6489*4bdc9457SAndroid Build Coastguard Worker .input_stride(40)
6490*4bdc9457SAndroid Build Coastguard Worker .output_stride(24)
6491*4bdc9457SAndroid Build Coastguard Worker .block_width(40)
6492*4bdc9457SAndroid Build Coastguard Worker .block_height(24)
6493*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6494*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(13)
6495*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6496*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6497*4bdc9457SAndroid Build Coastguard Worker }
6498*4bdc9457SAndroid Build Coastguard Worker
TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2,bh_56_bw_184_ies_19_oes_15)6499*4bdc9457SAndroid Build Coastguard Worker TEST(X16_TRANSPOSEC__8X8_REUSE_SWITCH_ZIP_NEON_2, bh_56_bw_184_ies_19_oes_15) {
6500*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
6501*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
6502*4bdc9457SAndroid Build Coastguard Worker .input_stride(189)
6503*4bdc9457SAndroid Build Coastguard Worker .output_stride(62)
6504*4bdc9457SAndroid Build Coastguard Worker .block_width(184)
6505*4bdc9457SAndroid Build Coastguard Worker .block_height(56)
6506*4bdc9457SAndroid Build Coastguard Worker .element_size(2)
6507*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(19)
6508*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(15)
6509*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
6510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x16_transposec_ukernel__8x8_reuse_switch_zip_neon);
6511*4bdc9457SAndroid Build Coastguard Worker }
6512*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
6513