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