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