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/x24-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(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_2)20*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
27*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
28*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
29*4bdc9457SAndroid Build Coastguard Worker }
30*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_2_bw_1_4)31*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
40*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
41*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
42*4bdc9457SAndroid Build Coastguard Worker }
43*4bdc9457SAndroid Build Coastguard Worker }
44*4bdc9457SAndroid Build Coastguard Worker }
45*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_4)46*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
53*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
54*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
55*4bdc9457SAndroid Build Coastguard Worker }
56*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_3_4)57*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
65*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
66*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
67*4bdc9457SAndroid Build Coastguard Worker }
68*4bdc9457SAndroid Build Coastguard Worker }
69*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_2_bw_3_4)70*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
78*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
79*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
80*4bdc9457SAndroid Build Coastguard Worker }
81*4bdc9457SAndroid Build Coastguard Worker }
82*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_2_bw_2)83*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
90*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
91*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
92*4bdc9457SAndroid Build Coastguard Worker }
93*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_2_2_bw_2)94*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
102*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
103*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
104*4bdc9457SAndroid Build Coastguard Worker }
105*4bdc9457SAndroid Build Coastguard Worker }
106*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_2_2_bw_4)107*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
115*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
116*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
117*4bdc9457SAndroid Build Coastguard Worker }
118*4bdc9457SAndroid Build Coastguard Worker }
119*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_2_2_bw_3_4)120*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
129*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
130*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
131*4bdc9457SAndroid Build Coastguard Worker }
132*4bdc9457SAndroid Build Coastguard Worker }
133*4bdc9457SAndroid Build Coastguard Worker }
134*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_2_is_4)135*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
142*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
143*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
144*4bdc9457SAndroid Build Coastguard Worker }
145*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_2_os_2)146*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
153*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
155*4bdc9457SAndroid Build Coastguard Worker }
156*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_1_bw_2_is_4_os_2)157*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, 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(3)
164*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
166*4bdc9457SAndroid Build Coastguard Worker }
167*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_17_bw_38_ies_14)168*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, bh_17_bw_38_ies_14) {
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(3)
175*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
176*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
178*4bdc9457SAndroid Build Coastguard Worker }
179*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_3_bw_10_oes_14)180*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, bh_3_bw_10_oes_14) {
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(3)
187*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
190*4bdc9457SAndroid Build Coastguard Worker }
191*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X2_SCALAR_3,bh_7_bw_46_ies_20_oes_16)192*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X2_SCALAR_3, bh_7_bw_46_ies_20_oes_16) {
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(3)
199*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
200*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
201*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
202*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x2_scalar);
203*4bdc9457SAndroid Build Coastguard Worker }
204*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_4)205*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
214*4bdc9457SAndroid Build Coastguard Worker }
215*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_2_bw_1_8)216*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
227*4bdc9457SAndroid Build Coastguard Worker }
228*4bdc9457SAndroid Build Coastguard Worker }
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_8)231*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
238*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
239*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
240*4bdc9457SAndroid Build Coastguard Worker }
241*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_5_8)242*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
250*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
251*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
252*4bdc9457SAndroid Build Coastguard Worker }
253*4bdc9457SAndroid Build Coastguard Worker }
254*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_2_bw_5_8)255*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
265*4bdc9457SAndroid Build Coastguard Worker }
266*4bdc9457SAndroid Build Coastguard Worker }
267*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_2_bw_4)268*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
275*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
276*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
277*4bdc9457SAndroid Build Coastguard Worker }
278*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_2_2_bw_4)279*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
287*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
288*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
289*4bdc9457SAndroid Build Coastguard Worker }
290*4bdc9457SAndroid Build Coastguard Worker }
291*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_2_2_bw_8)292*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
300*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
301*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
302*4bdc9457SAndroid Build Coastguard Worker }
303*4bdc9457SAndroid Build Coastguard Worker }
304*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_2_2_bw_5_8)305*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
314*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
315*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
316*4bdc9457SAndroid Build Coastguard Worker }
317*4bdc9457SAndroid Build Coastguard Worker }
318*4bdc9457SAndroid Build Coastguard Worker }
319*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_4_is_8)320*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
327*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
328*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
329*4bdc9457SAndroid Build Coastguard Worker }
330*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_4_os_2)331*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
338*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
339*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
340*4bdc9457SAndroid Build Coastguard Worker }
341*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_1_bw_4_is_8_os_2)342*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, 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(3)
349*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
350*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
351*4bdc9457SAndroid Build Coastguard Worker }
352*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_17_bw_76_ies_14)353*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, bh_17_bw_76_ies_14) {
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(3)
360*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
361*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
362*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
363*4bdc9457SAndroid Build Coastguard Worker }
364*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_3_bw_20_oes_14)365*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, bh_3_bw_20_oes_14) {
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(3)
372*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
375*4bdc9457SAndroid Build Coastguard Worker }
376*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__1X4_SCALAR_3,bh_7_bw_92_ies_20_oes_16)377*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__1X4_SCALAR_3, bh_7_bw_92_ies_20_oes_16) {
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(3)
384*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
385*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
386*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
387*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__1x4_scalar);
388*4bdc9457SAndroid Build Coastguard Worker }
389*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_1)390*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
399*4bdc9457SAndroid Build Coastguard Worker }
400*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_1_4_bw_1_2)401*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
412*4bdc9457SAndroid Build Coastguard Worker }
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker }
415*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_2)416*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
423*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
424*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
425*4bdc9457SAndroid Build Coastguard Worker }
426*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_2_2)427*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
435*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
436*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
437*4bdc9457SAndroid Build Coastguard Worker }
438*4bdc9457SAndroid Build Coastguard Worker }
439*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_4_bw_2_2)440*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
450*4bdc9457SAndroid Build Coastguard Worker }
451*4bdc9457SAndroid Build Coastguard Worker }
452*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_4_bw_1)453*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
460*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
461*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
462*4bdc9457SAndroid Build Coastguard Worker }
463*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_3_4_bw_1)464*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
472*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
473*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
474*4bdc9457SAndroid Build Coastguard Worker }
475*4bdc9457SAndroid Build Coastguard Worker }
476*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_3_4_bw_2)477*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
485*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
486*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
487*4bdc9457SAndroid Build Coastguard Worker }
488*4bdc9457SAndroid Build Coastguard Worker }
489*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_3_4_bw_2_2)490*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
499*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
500*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
501*4bdc9457SAndroid Build Coastguard Worker }
502*4bdc9457SAndroid Build Coastguard Worker }
503*4bdc9457SAndroid Build Coastguard Worker }
504*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_1_is_2)505*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
512*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
513*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
514*4bdc9457SAndroid Build Coastguard Worker }
515*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_1_os_4)516*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_2_bw_1_is_2_os_4)527*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, 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(3)
534*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
535*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
536*4bdc9457SAndroid Build Coastguard Worker }
537*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_34_bw_19_ies_14)538*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, bh_34_bw_19_ies_14) {
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(3)
545*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
546*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
547*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
548*4bdc9457SAndroid Build Coastguard Worker }
549*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_6_bw_5_oes_14)550*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, bh_6_bw_5_oes_14) {
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(3)
557*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
558*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
560*4bdc9457SAndroid Build Coastguard Worker }
561*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X1_SCALAR_3,bh_14_bw_23_ies_20_oes_16)562*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X1_SCALAR_3, bh_14_bw_23_ies_20_oes_16) {
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(3)
569*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
570*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
571*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
572*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x1_scalar);
573*4bdc9457SAndroid Build Coastguard Worker }
574*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_2)575*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
582*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
583*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
584*4bdc9457SAndroid Build Coastguard Worker }
585*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_1_4_bw_1_4)586*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
595*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
597*4bdc9457SAndroid Build Coastguard Worker }
598*4bdc9457SAndroid Build Coastguard Worker }
599*4bdc9457SAndroid Build Coastguard Worker }
600*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_4)601*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
608*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
609*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
610*4bdc9457SAndroid Build Coastguard Worker }
611*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_3_4)612*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
620*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
621*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
622*4bdc9457SAndroid Build Coastguard Worker }
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_4_bw_3_4)625*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_4_bw_2)638*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
647*4bdc9457SAndroid Build Coastguard Worker }
648*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_3_4_bw_2)649*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
659*4bdc9457SAndroid Build Coastguard Worker }
660*4bdc9457SAndroid Build Coastguard Worker }
661*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_3_4_bw_4)662*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
672*4bdc9457SAndroid Build Coastguard Worker }
673*4bdc9457SAndroid Build Coastguard Worker }
674*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_3_4_bw_3_4)675*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
684*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
685*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
686*4bdc9457SAndroid Build Coastguard Worker }
687*4bdc9457SAndroid Build Coastguard Worker }
688*4bdc9457SAndroid Build Coastguard Worker }
689*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_2_is_4)690*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
699*4bdc9457SAndroid Build Coastguard Worker }
700*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_2_os_4)701*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
708*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
709*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
710*4bdc9457SAndroid Build Coastguard Worker }
711*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_2_bw_2_is_4_os_4)712*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, 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(3)
719*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
721*4bdc9457SAndroid Build Coastguard Worker }
722*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_34_bw_38_ies_14)723*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, bh_34_bw_38_ies_14) {
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(3)
730*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
731*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
732*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
733*4bdc9457SAndroid Build Coastguard Worker }
734*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_6_bw_10_oes_14)735*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, bh_6_bw_10_oes_14) {
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(3)
742*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
743*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
745*4bdc9457SAndroid Build Coastguard Worker }
746*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_SCALAR_3,bh_14_bw_46_ies_20_oes_16)747*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_SCALAR_3, bh_14_bw_46_ies_20_oes_16) {
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(3)
754*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
755*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
756*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
757*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_scalar);
758*4bdc9457SAndroid Build Coastguard Worker }
759*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_4)760*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
769*4bdc9457SAndroid Build Coastguard Worker }
770*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_1_4_bw_1_8)771*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
782*4bdc9457SAndroid Build Coastguard Worker }
783*4bdc9457SAndroid Build Coastguard Worker }
784*4bdc9457SAndroid Build Coastguard Worker }
785*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_8)786*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
795*4bdc9457SAndroid Build Coastguard Worker }
796*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_5_8)797*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
805*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
806*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
807*4bdc9457SAndroid Build Coastguard Worker }
808*4bdc9457SAndroid Build Coastguard Worker }
809*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_4_bw_5_8)810*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
818*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
820*4bdc9457SAndroid Build Coastguard Worker }
821*4bdc9457SAndroid Build Coastguard Worker }
822*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_4_bw_4)823*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
830*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
831*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
832*4bdc9457SAndroid Build Coastguard Worker }
833*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_3_4_bw_4)834*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
842*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
843*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
844*4bdc9457SAndroid Build Coastguard Worker }
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_3_4_bw_8)847*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
855*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
856*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
857*4bdc9457SAndroid Build Coastguard Worker }
858*4bdc9457SAndroid Build Coastguard Worker }
859*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_3_4_bw_5_8)860*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
869*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
870*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
871*4bdc9457SAndroid Build Coastguard Worker }
872*4bdc9457SAndroid Build Coastguard Worker }
873*4bdc9457SAndroid Build Coastguard Worker }
874*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_4_is_8)875*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
882*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
883*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
884*4bdc9457SAndroid Build Coastguard Worker }
885*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_4_os_4)886*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
893*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
894*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_2_bw_4_is_8_os_4)897*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, 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(3)
904*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
905*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
906*4bdc9457SAndroid Build Coastguard Worker }
907*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_34_bw_76_ies_14)908*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, bh_34_bw_76_ies_14) {
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(3)
915*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
916*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
917*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
918*4bdc9457SAndroid Build Coastguard Worker }
919*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_6_bw_20_oes_14)920*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, bh_6_bw_20_oes_14) {
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(3)
927*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
928*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
930*4bdc9457SAndroid Build Coastguard Worker }
931*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X4_SCALAR_3,bh_14_bw_92_ies_20_oes_16)932*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X4_SCALAR_3, bh_14_bw_92_ies_20_oes_16) {
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(3)
939*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
940*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
941*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
942*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x4_scalar);
943*4bdc9457SAndroid Build Coastguard Worker }
944*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_1)945*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
952*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
953*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
954*4bdc9457SAndroid Build Coastguard Worker }
955*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_1_8_bw_1_2)956*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
965*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
967*4bdc9457SAndroid Build Coastguard Worker }
968*4bdc9457SAndroid Build Coastguard Worker }
969*4bdc9457SAndroid Build Coastguard Worker }
970*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_2)971*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
978*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
979*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
980*4bdc9457SAndroid Build Coastguard Worker }
981*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_2_2)982*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
990*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
991*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
992*4bdc9457SAndroid Build Coastguard Worker }
993*4bdc9457SAndroid Build Coastguard Worker }
994*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_8_bw_2_2)995*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1003*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1005*4bdc9457SAndroid Build Coastguard Worker }
1006*4bdc9457SAndroid Build Coastguard Worker }
1007*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_8_bw_1)1008*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1015*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1016*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1017*4bdc9457SAndroid Build Coastguard Worker }
1018*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_5_8_bw_1)1019*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1027*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1029*4bdc9457SAndroid Build Coastguard Worker }
1030*4bdc9457SAndroid Build Coastguard Worker }
1031*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_5_8_bw_2)1032*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1040*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1042*4bdc9457SAndroid Build Coastguard Worker }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_5_8_bw_2_2)1045*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1054*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1055*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1056*4bdc9457SAndroid Build Coastguard Worker }
1057*4bdc9457SAndroid Build Coastguard Worker }
1058*4bdc9457SAndroid Build Coastguard Worker }
1059*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_1_is_2)1060*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1067*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1068*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_1_os_8)1071*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1078*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1079*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1080*4bdc9457SAndroid Build Coastguard Worker }
1081*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_4_bw_1_is_2_os_8)1082*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, 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(3)
1089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1091*4bdc9457SAndroid Build Coastguard Worker }
1092*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_68_bw_19_ies_14)1093*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, bh_68_bw_19_ies_14) {
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(3)
1100*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
1101*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1102*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1103*4bdc9457SAndroid Build Coastguard Worker }
1104*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_12_bw_5_oes_14)1105*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, bh_12_bw_5_oes_14) {
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(3)
1112*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
1113*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1115*4bdc9457SAndroid Build Coastguard Worker }
1116*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X1_SCALAR_3,bh_28_bw_23_ies_20_oes_16)1117*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X1_SCALAR_3, bh_28_bw_23_ies_20_oes_16) {
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(3)
1124*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
1125*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
1126*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1127*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x1_scalar);
1128*4bdc9457SAndroid Build Coastguard Worker }
1129*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_2)1130*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1137*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1138*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1139*4bdc9457SAndroid Build Coastguard Worker }
1140*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_1_8_bw_1_4)1141*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1150*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1152*4bdc9457SAndroid Build Coastguard Worker }
1153*4bdc9457SAndroid Build Coastguard Worker }
1154*4bdc9457SAndroid Build Coastguard Worker }
1155*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_4)1156*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1163*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1164*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1165*4bdc9457SAndroid Build Coastguard Worker }
1166*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_3_4)1167*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1175*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1176*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1177*4bdc9457SAndroid Build Coastguard Worker }
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_8_bw_3_4)1180*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1188*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1190*4bdc9457SAndroid Build Coastguard Worker }
1191*4bdc9457SAndroid Build Coastguard Worker }
1192*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_8_bw_2)1193*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1200*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1201*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1202*4bdc9457SAndroid Build Coastguard Worker }
1203*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_5_8_bw_2)1204*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1212*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1214*4bdc9457SAndroid Build Coastguard Worker }
1215*4bdc9457SAndroid Build Coastguard Worker }
1216*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_5_8_bw_4)1217*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1225*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker }
1229*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_5_8_bw_3_4)1230*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1239*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1240*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1241*4bdc9457SAndroid Build Coastguard Worker }
1242*4bdc9457SAndroid Build Coastguard Worker }
1243*4bdc9457SAndroid Build Coastguard Worker }
1244*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_2_is_4)1245*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1252*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_2_os_8)1256*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1263*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_4_bw_2_is_4_os_8)1267*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, 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(3)
1274*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1275*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1276*4bdc9457SAndroid Build Coastguard Worker }
1277*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_68_bw_38_ies_14)1278*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, bh_68_bw_38_ies_14) {
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(3)
1285*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
1286*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1287*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1288*4bdc9457SAndroid Build Coastguard Worker }
1289*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_12_bw_10_oes_14)1290*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, bh_12_bw_10_oes_14) {
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(3)
1297*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
1298*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1300*4bdc9457SAndroid Build Coastguard Worker }
1301*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X2_SCALAR_3,bh_28_bw_46_ies_20_oes_16)1302*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X2_SCALAR_3, bh_28_bw_46_ies_20_oes_16) {
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(3)
1309*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
1310*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
1311*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1312*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x2_scalar);
1313*4bdc9457SAndroid Build Coastguard Worker }
1314*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_4)1315*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1322*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1324*4bdc9457SAndroid Build Coastguard Worker }
1325*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_1_8_bw_1_8)1326*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1335*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1337*4bdc9457SAndroid Build Coastguard Worker }
1338*4bdc9457SAndroid Build Coastguard Worker }
1339*4bdc9457SAndroid Build Coastguard Worker }
1340*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_8)1341*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1348*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1349*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1350*4bdc9457SAndroid Build Coastguard Worker }
1351*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_5_8)1352*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1360*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1361*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1362*4bdc9457SAndroid Build Coastguard Worker }
1363*4bdc9457SAndroid Build Coastguard Worker }
1364*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_8_bw_5_8)1365*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1373*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1375*4bdc9457SAndroid Build Coastguard Worker }
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_8_bw_4)1378*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1385*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1386*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1387*4bdc9457SAndroid Build Coastguard Worker }
1388*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_5_8_bw_4)1389*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1397*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1398*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1399*4bdc9457SAndroid Build Coastguard Worker }
1400*4bdc9457SAndroid Build Coastguard Worker }
1401*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_5_8_bw_8)1402*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1410*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_5_8_bw_5_8)1415*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1424*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1425*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1426*4bdc9457SAndroid Build Coastguard Worker }
1427*4bdc9457SAndroid Build Coastguard Worker }
1428*4bdc9457SAndroid Build Coastguard Worker }
1429*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_4_is_8)1430*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1437*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1438*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1439*4bdc9457SAndroid Build Coastguard Worker }
1440*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_4_os_8)1441*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1448*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_4_bw_4_is_8_os_8)1452*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, 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(3)
1459*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1460*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1461*4bdc9457SAndroid Build Coastguard Worker }
1462*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_68_bw_76_ies_14)1463*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, bh_68_bw_76_ies_14) {
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(3)
1470*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
1471*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1472*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1473*4bdc9457SAndroid Build Coastguard Worker }
1474*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_12_bw_20_oes_14)1475*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, bh_12_bw_20_oes_14) {
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(3)
1482*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
1483*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1484*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1485*4bdc9457SAndroid Build Coastguard Worker }
1486*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SCALAR_3,bh_28_bw_92_ies_20_oes_16)1487*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SCALAR_3, bh_28_bw_92_ies_20_oes_16) {
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(3)
1494*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
1495*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
1496*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1497*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_scalar);
1498*4bdc9457SAndroid Build Coastguard Worker }
1499*4bdc9457SAndroid Build Coastguard Worker
1500*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_2)1501*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_2) {
1502*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1503*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1504*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1505*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1506*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1507*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1508*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1509*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1511*4bdc9457SAndroid Build Coastguard Worker }
1512*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_1_4_bw_1_4)1513*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_1_4_bw_1_4) {
1514*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1515*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 4; ++i){
1516*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 4; ++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(3)
1523*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1524*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1525*4bdc9457SAndroid Build Coastguard Worker }
1526*4bdc9457SAndroid Build Coastguard Worker }
1527*4bdc9457SAndroid Build Coastguard Worker }
1528*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_4)1529*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_4) {
1530*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1531*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1532*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1533*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1534*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1535*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1536*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1537*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1538*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1539*4bdc9457SAndroid Build Coastguard Worker }
1540*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_3_4)1541*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_3_4) {
1542*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1543*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1544*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1545*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1546*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1547*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1548*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1549*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1550*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1552*4bdc9457SAndroid Build Coastguard Worker }
1553*4bdc9457SAndroid Build Coastguard Worker }
1554*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_4_bw_3_4)1555*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_4_bw_3_4) {
1556*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1557*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1558*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1559*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1560*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1561*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1562*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1563*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1564*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1565*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1566*4bdc9457SAndroid Build Coastguard Worker }
1567*4bdc9457SAndroid Build Coastguard Worker }
1568*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_4_bw_2)1569*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_4_bw_2) {
1570*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1571*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1572*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1573*4bdc9457SAndroid Build Coastguard Worker .output_stride(10)
1574*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1575*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1576*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1577*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1579*4bdc9457SAndroid Build Coastguard Worker }
1580*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_3_4_bw_2)1581*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_3_4_bw_2){
1582*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1583*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1584*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1585*4bdc9457SAndroid Build Coastguard Worker .input_stride(19)
1586*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1587*4bdc9457SAndroid Build Coastguard Worker .block_width(5)
1588*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1589*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1590*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1591*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1592*4bdc9457SAndroid Build Coastguard Worker }
1593*4bdc9457SAndroid Build Coastguard Worker }
1594*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_3_4_bw_4)1595*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_3_4_bw_4){
1596*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1597*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1598*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1599*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1600*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1601*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1602*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1603*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1604*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1606*4bdc9457SAndroid Build Coastguard Worker }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_3_4_bw_3_4)1609*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_3_4_bw_3_4) {
1610*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1611*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 3; i < 4; ++i){
1612*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 3; j < 4; ++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(3)
1619*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1620*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1621*4bdc9457SAndroid Build Coastguard Worker }
1622*4bdc9457SAndroid Build Coastguard Worker }
1623*4bdc9457SAndroid Build Coastguard Worker }
1624*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_2_is_4)1625*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_2_is_4) {
1626*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1627*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1628*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1629*4bdc9457SAndroid Build Coastguard Worker .output_stride(2)
1630*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1631*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1632*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1633*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1635*4bdc9457SAndroid Build Coastguard Worker }
1636*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_2_os_4)1637*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_2_os_4) {
1638*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1639*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1640*4bdc9457SAndroid Build Coastguard Worker .input_stride(2)
1641*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1642*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1643*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1644*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1645*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1647*4bdc9457SAndroid Build Coastguard Worker }
1648*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_2_bw_2_is_4_os_4)1649*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_2_bw_2_is_4_os_4) {
1650*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1651*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1652*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1653*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1654*4bdc9457SAndroid Build Coastguard Worker .block_width(2)
1655*4bdc9457SAndroid Build Coastguard Worker .block_height(2)
1656*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1657*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1659*4bdc9457SAndroid Build Coastguard Worker }
1660*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_34_bw_38_ies_14)1661*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_34_bw_38_ies_14) {
1662*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1663*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1664*4bdc9457SAndroid Build Coastguard Worker .input_stride(38)
1665*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1666*4bdc9457SAndroid Build Coastguard Worker .block_width(38)
1667*4bdc9457SAndroid Build Coastguard Worker .block_height(34)
1668*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1669*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
1670*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1672*4bdc9457SAndroid Build Coastguard Worker }
1673*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_6_bw_10_oes_14)1674*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_6_bw_10_oes_14) {
1675*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1676*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1677*4bdc9457SAndroid Build Coastguard Worker .input_stride(10)
1678*4bdc9457SAndroid Build Coastguard Worker .output_stride(6)
1679*4bdc9457SAndroid Build Coastguard Worker .block_width(10)
1680*4bdc9457SAndroid Build Coastguard Worker .block_height(6)
1681*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1682*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
1683*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1684*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1685*4bdc9457SAndroid Build Coastguard Worker }
1686*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3,bh_14_bw_46_ies_20_oes_16)1687*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__2X2_NEON_TBL_3, bh_14_bw_46_ies_20_oes_16) {
1688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1689*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1690*4bdc9457SAndroid Build Coastguard Worker .input_stride(51)
1691*4bdc9457SAndroid Build Coastguard Worker .output_stride(20)
1692*4bdc9457SAndroid Build Coastguard Worker .block_width(46)
1693*4bdc9457SAndroid Build Coastguard Worker .block_height(14)
1694*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1695*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
1696*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
1697*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__2x2_neon_tbl);
1699*4bdc9457SAndroid Build Coastguard Worker }
1700*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1701*4bdc9457SAndroid Build Coastguard Worker
1702*4bdc9457SAndroid Build Coastguard Worker
1703*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM64
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_4)1704*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_4) {
1705*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1706*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1707*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1708*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1709*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1710*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1711*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1712*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1713*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1714*4bdc9457SAndroid Build Coastguard Worker }
1715*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_1_8_bw_1_8)1716*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_1_8_bw_1_8) {
1717*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1718*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
1719*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++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(3)
1726*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1728*4bdc9457SAndroid Build Coastguard Worker }
1729*4bdc9457SAndroid Build Coastguard Worker }
1730*4bdc9457SAndroid Build Coastguard Worker }
1731*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_8)1732*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_8) {
1733*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1734*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1735*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1736*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1737*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1738*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1739*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1740*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1741*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1742*4bdc9457SAndroid Build Coastguard Worker }
1743*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_5_8)1744*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_5_8) {
1745*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1746*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1747*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1748*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1749*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1750*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1751*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1752*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1753*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1754*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1755*4bdc9457SAndroid Build Coastguard Worker }
1756*4bdc9457SAndroid Build Coastguard Worker }
1757*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_8_bw_5_8)1758*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_8_bw_5_8) {
1759*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1760*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1761*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1762*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1763*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1764*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1765*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1766*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1767*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1768*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1769*4bdc9457SAndroid Build Coastguard Worker }
1770*4bdc9457SAndroid Build Coastguard Worker }
1771*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_8_bw_4)1772*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_8_bw_4) {
1773*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1774*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1775*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1776*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1777*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1778*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1779*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1780*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1782*4bdc9457SAndroid Build Coastguard Worker }
1783*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_5_8_bw_4)1784*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_5_8_bw_4){
1785*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1786*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1787*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1788*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
1789*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1790*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
1791*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1792*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1793*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1795*4bdc9457SAndroid Build Coastguard Worker }
1796*4bdc9457SAndroid Build Coastguard Worker }
1797*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_5_8_bw_8)1798*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_5_8_bw_8){
1799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1800*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1801*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1802*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1803*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1804*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1805*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1806*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1807*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1809*4bdc9457SAndroid Build Coastguard Worker }
1810*4bdc9457SAndroid Build Coastguard Worker }
1811*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_5_8_bw_5_8)1812*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_5_8_bw_5_8) {
1813*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1814*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1815*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++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(3)
1822*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1823*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1824*4bdc9457SAndroid Build Coastguard Worker }
1825*4bdc9457SAndroid Build Coastguard Worker }
1826*4bdc9457SAndroid Build Coastguard Worker }
1827*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_4_is_8)1828*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_4_is_8) {
1829*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1830*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1831*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1832*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1833*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1834*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1835*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1836*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1838*4bdc9457SAndroid Build Coastguard Worker }
1839*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_4_os_8)1840*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_4_os_8) {
1841*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1842*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1843*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1844*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1845*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1846*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1847*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1848*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1849*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1850*4bdc9457SAndroid Build Coastguard Worker }
1851*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_4_bw_4_is_8_os_8)1852*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_4_bw_4_is_8_os_8) {
1853*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1854*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1855*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1856*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1857*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1858*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1859*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1860*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1861*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1862*4bdc9457SAndroid Build Coastguard Worker }
1863*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_68_bw_76_ies_14)1864*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_68_bw_76_ies_14) {
1865*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1866*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1867*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
1868*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
1869*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
1870*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
1871*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1872*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
1873*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1874*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1875*4bdc9457SAndroid Build Coastguard Worker }
1876*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_12_bw_20_oes_14)1877*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_12_bw_20_oes_14) {
1878*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1879*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1880*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
1881*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
1882*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
1883*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
1884*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1885*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
1886*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1888*4bdc9457SAndroid Build Coastguard Worker }
1889*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3,bh_28_bw_92_ies_20_oes_16)1890*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_AARCH64_NEON_TBL_3, bh_28_bw_92_ies_20_oes_16) {
1891*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
1892*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1893*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
1894*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
1895*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
1896*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
1897*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1898*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
1899*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
1900*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_aarch64_neon_tbl);
1902*4bdc9457SAndroid Build Coastguard Worker }
1903*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM64
1904*4bdc9457SAndroid Build Coastguard Worker
1905*4bdc9457SAndroid Build Coastguard Worker
1906*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_4)1907*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_4) {
1908*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1909*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1910*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1911*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1912*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1913*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1914*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1915*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1916*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1917*4bdc9457SAndroid Build Coastguard Worker }
1918*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_1_8_bw_1_8)1919*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_1_8_bw_1_8) {
1920*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1921*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 1; i <= 8; ++i){
1922*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 1; j <= 8; ++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(3)
1929*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1930*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1931*4bdc9457SAndroid Build Coastguard Worker }
1932*4bdc9457SAndroid Build Coastguard Worker }
1933*4bdc9457SAndroid Build Coastguard Worker }
1934*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_8)1935*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_8) {
1936*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1937*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1938*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
1939*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
1940*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
1941*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1942*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1943*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1944*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1945*4bdc9457SAndroid Build Coastguard Worker }
1946*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_5_8)1947*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_5_8) {
1948*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1949*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1950*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1951*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1952*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1953*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1954*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
1955*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1956*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1957*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1958*4bdc9457SAndroid Build Coastguard Worker }
1959*4bdc9457SAndroid Build Coastguard Worker }
1960*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_8_bw_5_8)1961*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_8_bw_5_8) {
1962*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1963*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1964*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1965*4bdc9457SAndroid Build Coastguard Worker .input_stride(i)
1966*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
1967*4bdc9457SAndroid Build Coastguard Worker .block_width(i)
1968*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1969*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1970*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1971*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1972*4bdc9457SAndroid Build Coastguard Worker }
1973*4bdc9457SAndroid Build Coastguard Worker }
1974*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_8_bw_4)1975*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_8_bw_4) {
1976*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1977*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1978*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
1979*4bdc9457SAndroid Build Coastguard Worker .output_stride(16)
1980*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
1981*4bdc9457SAndroid Build Coastguard Worker .block_height(8)
1982*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1983*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1984*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1985*4bdc9457SAndroid Build Coastguard Worker }
1986*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_5_8_bw_4)1987*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_5_8_bw_4){
1988*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
1989*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
1990*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
1991*4bdc9457SAndroid Build Coastguard Worker .input_stride(21)
1992*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
1993*4bdc9457SAndroid Build Coastguard Worker .block_width(7)
1994*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
1995*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
1996*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
1997*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
1998*4bdc9457SAndroid Build Coastguard Worker }
1999*4bdc9457SAndroid Build Coastguard Worker }
2000*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_5_8_bw_8)2001*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_5_8_bw_8){
2002*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2003*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2004*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2005*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2006*4bdc9457SAndroid Build Coastguard Worker .output_stride(i)
2007*4bdc9457SAndroid Build Coastguard Worker .block_width(8)
2008*4bdc9457SAndroid Build Coastguard Worker .block_height(i)
2009*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2010*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2012*4bdc9457SAndroid Build Coastguard Worker }
2013*4bdc9457SAndroid Build Coastguard Worker }
2014*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_5_8_bw_5_8)2015*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_5_8_bw_5_8) {
2016*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2017*4bdc9457SAndroid Build Coastguard Worker for(size_t i = 5; i < 8; ++i){
2018*4bdc9457SAndroid Build Coastguard Worker for(size_t j = 5; j < 8; ++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(3)
2025*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2026*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2027*4bdc9457SAndroid Build Coastguard Worker }
2028*4bdc9457SAndroid Build Coastguard Worker }
2029*4bdc9457SAndroid Build Coastguard Worker }
2030*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_4_is_8)2031*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_4_is_8) {
2032*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2033*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2034*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2035*4bdc9457SAndroid Build Coastguard Worker .output_stride(4)
2036*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2037*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2038*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2039*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2041*4bdc9457SAndroid Build Coastguard Worker }
2042*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_4_os_8)2043*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_4_os_8) {
2044*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2045*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2046*4bdc9457SAndroid Build Coastguard Worker .input_stride(4)
2047*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2048*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2049*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2050*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2051*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2052*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2053*4bdc9457SAndroid Build Coastguard Worker }
2054*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_4_bw_4_is_8_os_8)2055*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_4_bw_4_is_8_os_8) {
2056*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2057*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2058*4bdc9457SAndroid Build Coastguard Worker .input_stride(8)
2059*4bdc9457SAndroid Build Coastguard Worker .output_stride(8)
2060*4bdc9457SAndroid Build Coastguard Worker .block_width(4)
2061*4bdc9457SAndroid Build Coastguard Worker .block_height(4)
2062*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2063*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2064*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2065*4bdc9457SAndroid Build Coastguard Worker }
2066*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_68_bw_76_ies_14)2067*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_68_bw_76_ies_14) {
2068*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2069*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2070*4bdc9457SAndroid Build Coastguard Worker .input_stride(76)
2071*4bdc9457SAndroid Build Coastguard Worker .output_stride(68)
2072*4bdc9457SAndroid Build Coastguard Worker .block_width(76)
2073*4bdc9457SAndroid Build Coastguard Worker .block_height(68)
2074*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2075*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(14)
2076*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2077*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2078*4bdc9457SAndroid Build Coastguard Worker }
2079*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_12_bw_20_oes_14)2080*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_12_bw_20_oes_14) {
2081*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2082*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2083*4bdc9457SAndroid Build Coastguard Worker .input_stride(20)
2084*4bdc9457SAndroid Build Coastguard Worker .output_stride(12)
2085*4bdc9457SAndroid Build Coastguard Worker .block_width(20)
2086*4bdc9457SAndroid Build Coastguard Worker .block_height(12)
2087*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2088*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(14)
2089*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2091*4bdc9457SAndroid Build Coastguard Worker }
2092*4bdc9457SAndroid Build Coastguard Worker
TEST(X24_TRANSPOSEC__4X4_SSSE3_3,bh_28_bw_92_ies_20_oes_16)2093*4bdc9457SAndroid Build Coastguard Worker TEST(X24_TRANSPOSEC__4X4_SSSE3_3, bh_28_bw_92_ies_20_oes_16) {
2094*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
2095*4bdc9457SAndroid Build Coastguard Worker TransposeMicrokernelTester()
2096*4bdc9457SAndroid Build Coastguard Worker .input_stride(97)
2097*4bdc9457SAndroid Build Coastguard Worker .output_stride(34)
2098*4bdc9457SAndroid Build Coastguard Worker .block_width(92)
2099*4bdc9457SAndroid Build Coastguard Worker .block_height(28)
2100*4bdc9457SAndroid Build Coastguard Worker .element_size(3)
2101*4bdc9457SAndroid Build Coastguard Worker .input_element_stride(20)
2102*4bdc9457SAndroid Build Coastguard Worker .output_element_stride(16)
2103*4bdc9457SAndroid Build Coastguard Worker .iterations(1)
2104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_x24_transposec_ukernel__4x4_ssse3);
2105*4bdc9457SAndroid Build Coastguard Worker }
2106*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2107