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/qu8-vmul-minmax-fp32.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/vmul.h>
18*4bdc9457SAndroid Build Coastguard Worker #include "vmul-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(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,batch_eq_8)22*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8, batch_eq_8) {
23*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
24*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
25*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
26*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
27*4bdc9457SAndroid Build Coastguard Worker }
28*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,batch_div_8)29*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
33*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
34*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
35*4bdc9457SAndroid Build Coastguard Worker }
36*4bdc9457SAndroid Build Coastguard Worker }
37*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,batch_lt_8)38*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
42*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
43*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
44*4bdc9457SAndroid Build Coastguard Worker }
45*4bdc9457SAndroid Build Coastguard Worker }
46*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,batch_gt_8)47*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
51*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
52*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
53*4bdc9457SAndroid Build Coastguard Worker }
54*4bdc9457SAndroid Build Coastguard Worker }
55*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,inplace_a)56*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
60*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
61*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
62*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
63*4bdc9457SAndroid Build Coastguard Worker }
64*4bdc9457SAndroid Build Coastguard Worker }
65*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,inplace_b)66*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
70*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
71*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
72*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
73*4bdc9457SAndroid Build Coastguard Worker }
74*4bdc9457SAndroid Build Coastguard Worker }
75*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,inplace_a_and_b)76*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
84*4bdc9457SAndroid Build Coastguard Worker }
85*4bdc9457SAndroid Build Coastguard Worker }
86*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,a_zero_point)87*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
95*4bdc9457SAndroid Build Coastguard Worker }
96*4bdc9457SAndroid Build Coastguard Worker }
97*4bdc9457SAndroid Build Coastguard Worker }
98*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,b_zero_point)99*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
107*4bdc9457SAndroid Build Coastguard Worker }
108*4bdc9457SAndroid Build Coastguard Worker }
109*4bdc9457SAndroid Build Coastguard Worker }
110*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,y_zero_point)111*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
119*4bdc9457SAndroid Build Coastguard Worker }
120*4bdc9457SAndroid Build Coastguard Worker }
121*4bdc9457SAndroid Build Coastguard Worker }
122*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,a_scale)123*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
131*4bdc9457SAndroid Build Coastguard Worker }
132*4bdc9457SAndroid Build Coastguard Worker }
133*4bdc9457SAndroid Build Coastguard Worker }
134*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,b_scale)135*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
143*4bdc9457SAndroid Build Coastguard Worker }
144*4bdc9457SAndroid Build Coastguard Worker }
145*4bdc9457SAndroid Build Coastguard Worker }
146*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,y_scale)147*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
155*4bdc9457SAndroid Build Coastguard Worker }
156*4bdc9457SAndroid Build Coastguard Worker }
157*4bdc9457SAndroid Build Coastguard Worker }
158*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,qmin)159*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
163*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
164*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
166*4bdc9457SAndroid Build Coastguard Worker }
167*4bdc9457SAndroid Build Coastguard Worker }
168*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X8,qmax)169*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
173*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
174*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
175*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,batch_eq_16)182*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16, batch_eq_16) {
183*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
184*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
185*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
186*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
187*4bdc9457SAndroid Build Coastguard Worker }
188*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,batch_div_16)189*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
193*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
194*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
195*4bdc9457SAndroid Build Coastguard Worker }
196*4bdc9457SAndroid Build Coastguard Worker }
197*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,batch_lt_16)198*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
202*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
203*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
204*4bdc9457SAndroid Build Coastguard Worker }
205*4bdc9457SAndroid Build Coastguard Worker }
206*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,batch_gt_16)207*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
211*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
212*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
213*4bdc9457SAndroid Build Coastguard Worker }
214*4bdc9457SAndroid Build Coastguard Worker }
215*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,inplace_a)216*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
220*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
221*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
222*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
223*4bdc9457SAndroid Build Coastguard Worker }
224*4bdc9457SAndroid Build Coastguard Worker }
225*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,inplace_b)226*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
230*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
231*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
232*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
233*4bdc9457SAndroid Build Coastguard Worker }
234*4bdc9457SAndroid Build Coastguard Worker }
235*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,inplace_a_and_b)236*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
244*4bdc9457SAndroid Build Coastguard Worker }
245*4bdc9457SAndroid Build Coastguard Worker }
246*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,a_zero_point)247*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
255*4bdc9457SAndroid Build Coastguard Worker }
256*4bdc9457SAndroid Build Coastguard Worker }
257*4bdc9457SAndroid Build Coastguard Worker }
258*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,b_zero_point)259*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
267*4bdc9457SAndroid Build Coastguard Worker }
268*4bdc9457SAndroid Build Coastguard Worker }
269*4bdc9457SAndroid Build Coastguard Worker }
270*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,y_zero_point)271*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
279*4bdc9457SAndroid Build Coastguard Worker }
280*4bdc9457SAndroid Build Coastguard Worker }
281*4bdc9457SAndroid Build Coastguard Worker }
282*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,a_scale)283*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
291*4bdc9457SAndroid Build Coastguard Worker }
292*4bdc9457SAndroid Build Coastguard Worker }
293*4bdc9457SAndroid Build Coastguard Worker }
294*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,b_scale)295*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
303*4bdc9457SAndroid Build Coastguard Worker }
304*4bdc9457SAndroid Build Coastguard Worker }
305*4bdc9457SAndroid Build Coastguard Worker }
306*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,y_scale)307*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
315*4bdc9457SAndroid Build Coastguard Worker }
316*4bdc9457SAndroid Build Coastguard Worker }
317*4bdc9457SAndroid Build Coastguard Worker }
318*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,qmin)319*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
323*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
324*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
325*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
326*4bdc9457SAndroid Build Coastguard Worker }
327*4bdc9457SAndroid Build Coastguard Worker }
328*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD64_X16,qmax)329*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
333*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
334*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
335*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,batch_eq_16)342*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, batch_eq_16) {
343*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
344*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
345*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
346*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
347*4bdc9457SAndroid Build Coastguard Worker }
348*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,batch_div_16)349*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, batch_div_16) {
350*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
351*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
352*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
353*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
354*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
355*4bdc9457SAndroid Build Coastguard Worker }
356*4bdc9457SAndroid Build Coastguard Worker }
357*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,batch_lt_16)358*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, batch_lt_16) {
359*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
360*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
361*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
362*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
363*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
364*4bdc9457SAndroid Build Coastguard Worker }
365*4bdc9457SAndroid Build Coastguard Worker }
366*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,batch_gt_16)367*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, batch_gt_16) {
368*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
369*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
370*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
371*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
372*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
373*4bdc9457SAndroid Build Coastguard Worker }
374*4bdc9457SAndroid Build Coastguard Worker }
375*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,inplace_a)376*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, inplace_a) {
377*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
378*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
379*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
380*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
381*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
382*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
383*4bdc9457SAndroid Build Coastguard Worker }
384*4bdc9457SAndroid Build Coastguard Worker }
385*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,inplace_b)386*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, inplace_b) {
387*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
388*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
389*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
390*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
391*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
392*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
393*4bdc9457SAndroid Build Coastguard Worker }
394*4bdc9457SAndroid Build Coastguard Worker }
395*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,inplace_a_and_b)396*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, 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 <= 80; batch_size += 15) {
399*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
404*4bdc9457SAndroid Build Coastguard Worker }
405*4bdc9457SAndroid Build Coastguard Worker }
406*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,a_zero_point)407*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, 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 <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
415*4bdc9457SAndroid Build Coastguard Worker }
416*4bdc9457SAndroid Build Coastguard Worker }
417*4bdc9457SAndroid Build Coastguard Worker }
418*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,b_zero_point)419*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, 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 <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
427*4bdc9457SAndroid Build Coastguard Worker }
428*4bdc9457SAndroid Build Coastguard Worker }
429*4bdc9457SAndroid Build Coastguard Worker }
430*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,y_zero_point)431*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, 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 <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
439*4bdc9457SAndroid Build Coastguard Worker }
440*4bdc9457SAndroid Build Coastguard Worker }
441*4bdc9457SAndroid Build Coastguard Worker }
442*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,a_scale)443*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, a_scale) {
444*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
445*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
446*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
447*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
451*4bdc9457SAndroid Build Coastguard Worker }
452*4bdc9457SAndroid Build Coastguard Worker }
453*4bdc9457SAndroid Build Coastguard Worker }
454*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,b_scale)455*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, b_scale) {
456*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
457*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
458*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
459*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
463*4bdc9457SAndroid Build Coastguard Worker }
464*4bdc9457SAndroid Build Coastguard Worker }
465*4bdc9457SAndroid Build Coastguard Worker }
466*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,y_scale)467*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, y_scale) {
468*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
469*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
470*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
471*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
475*4bdc9457SAndroid Build Coastguard Worker }
476*4bdc9457SAndroid Build Coastguard Worker }
477*4bdc9457SAndroid Build Coastguard Worker }
478*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,qmin)479*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, qmin) {
480*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
481*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
482*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
483*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
484*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
485*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
486*4bdc9457SAndroid Build Coastguard Worker }
487*4bdc9457SAndroid Build Coastguard Worker }
488*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16,qmax)489*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEON_LD128_X16, qmax) {
490*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
491*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
492*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
493*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
494*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neon_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neon_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,batch_eq_8)502*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, batch_eq_8) {
503*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
504*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
505*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
506*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
507*4bdc9457SAndroid Build Coastguard Worker }
508*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,batch_div_8)509*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, batch_div_8) {
510*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
511*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
512*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
513*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
514*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
515*4bdc9457SAndroid Build Coastguard Worker }
516*4bdc9457SAndroid Build Coastguard Worker }
517*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,batch_lt_8)518*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, batch_lt_8) {
519*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
520*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
521*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
522*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
523*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
524*4bdc9457SAndroid Build Coastguard Worker }
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,batch_gt_8)527*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, batch_gt_8) {
528*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
529*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
530*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
531*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
532*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
533*4bdc9457SAndroid Build Coastguard Worker }
534*4bdc9457SAndroid Build Coastguard Worker }
535*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,inplace_a)536*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, inplace_a) {
537*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
538*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
539*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
540*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
541*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
542*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
543*4bdc9457SAndroid Build Coastguard Worker }
544*4bdc9457SAndroid Build Coastguard Worker }
545*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,inplace_b)546*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, inplace_b) {
547*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
548*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
549*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
550*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
551*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
552*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
553*4bdc9457SAndroid Build Coastguard Worker }
554*4bdc9457SAndroid Build Coastguard Worker }
555*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,inplace_a_and_b)556*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, inplace_a_and_b) {
557*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
558*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
559*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
564*4bdc9457SAndroid Build Coastguard Worker }
565*4bdc9457SAndroid Build Coastguard Worker }
566*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,a_zero_point)567*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, a_zero_point) {
568*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
569*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
575*4bdc9457SAndroid Build Coastguard Worker }
576*4bdc9457SAndroid Build Coastguard Worker }
577*4bdc9457SAndroid Build Coastguard Worker }
578*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,b_zero_point)579*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, b_zero_point) {
580*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
581*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
587*4bdc9457SAndroid Build Coastguard Worker }
588*4bdc9457SAndroid Build Coastguard Worker }
589*4bdc9457SAndroid Build Coastguard Worker }
590*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,y_zero_point)591*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, y_zero_point) {
592*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
593*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
599*4bdc9457SAndroid Build Coastguard Worker }
600*4bdc9457SAndroid Build Coastguard Worker }
601*4bdc9457SAndroid Build Coastguard Worker }
602*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,a_scale)603*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, a_scale) {
604*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
605*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
606*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
607*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
611*4bdc9457SAndroid Build Coastguard Worker }
612*4bdc9457SAndroid Build Coastguard Worker }
613*4bdc9457SAndroid Build Coastguard Worker }
614*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,b_scale)615*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, b_scale) {
616*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
617*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
618*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
619*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
623*4bdc9457SAndroid Build Coastguard Worker }
624*4bdc9457SAndroid Build Coastguard Worker }
625*4bdc9457SAndroid Build Coastguard Worker }
626*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,y_scale)627*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, y_scale) {
628*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
629*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
630*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
631*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker }
638*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,qmin)639*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, qmin) {
640*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
641*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
642*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
643*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
644*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
645*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
646*4bdc9457SAndroid Build Coastguard Worker }
647*4bdc9457SAndroid Build Coastguard Worker }
648*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8,qmax)649*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X8, qmax) {
650*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
651*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
652*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
653*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
654*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
655*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x8, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,batch_eq_16)662*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, batch_eq_16) {
663*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
664*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
665*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
666*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
667*4bdc9457SAndroid Build Coastguard Worker }
668*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,batch_div_16)669*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, batch_div_16) {
670*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
671*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
672*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
673*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
674*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
675*4bdc9457SAndroid Build Coastguard Worker }
676*4bdc9457SAndroid Build Coastguard Worker }
677*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,batch_lt_16)678*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, batch_lt_16) {
679*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
680*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
681*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
682*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
683*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
684*4bdc9457SAndroid Build Coastguard Worker }
685*4bdc9457SAndroid Build Coastguard Worker }
686*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,batch_gt_16)687*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, batch_gt_16) {
688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
689*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
690*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
691*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
692*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
693*4bdc9457SAndroid Build Coastguard Worker }
694*4bdc9457SAndroid Build Coastguard Worker }
695*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,inplace_a)696*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, inplace_a) {
697*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
698*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
699*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
700*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
701*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
702*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
703*4bdc9457SAndroid Build Coastguard Worker }
704*4bdc9457SAndroid Build Coastguard Worker }
705*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,inplace_b)706*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, inplace_b) {
707*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
708*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
709*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
710*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
711*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
712*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
713*4bdc9457SAndroid Build Coastguard Worker }
714*4bdc9457SAndroid Build Coastguard Worker }
715*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,inplace_a_and_b)716*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, inplace_a_and_b) {
717*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
718*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
719*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
724*4bdc9457SAndroid Build Coastguard Worker }
725*4bdc9457SAndroid Build Coastguard Worker }
726*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,a_zero_point)727*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, a_zero_point) {
728*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
735*4bdc9457SAndroid Build Coastguard Worker }
736*4bdc9457SAndroid Build Coastguard Worker }
737*4bdc9457SAndroid Build Coastguard Worker }
738*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,b_zero_point)739*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, b_zero_point) {
740*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
747*4bdc9457SAndroid Build Coastguard Worker }
748*4bdc9457SAndroid Build Coastguard Worker }
749*4bdc9457SAndroid Build Coastguard Worker }
750*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,y_zero_point)751*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, y_zero_point) {
752*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
759*4bdc9457SAndroid Build Coastguard Worker }
760*4bdc9457SAndroid Build Coastguard Worker }
761*4bdc9457SAndroid Build Coastguard Worker }
762*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,a_scale)763*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, a_scale) {
764*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
771*4bdc9457SAndroid Build Coastguard Worker }
772*4bdc9457SAndroid Build Coastguard Worker }
773*4bdc9457SAndroid Build Coastguard Worker }
774*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,b_scale)775*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, b_scale) {
776*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
783*4bdc9457SAndroid Build Coastguard Worker }
784*4bdc9457SAndroid Build Coastguard Worker }
785*4bdc9457SAndroid Build Coastguard Worker }
786*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,y_scale)787*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, y_scale) {
788*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
795*4bdc9457SAndroid Build Coastguard Worker }
796*4bdc9457SAndroid Build Coastguard Worker }
797*4bdc9457SAndroid Build Coastguard Worker }
798*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,qmin)799*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, qmin) {
800*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
801*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
802*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
803*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
804*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
805*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
806*4bdc9457SAndroid Build Coastguard Worker }
807*4bdc9457SAndroid Build Coastguard Worker }
808*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16,qmax)809*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD64_X16, qmax) {
810*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
811*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
812*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
813*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
814*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
815*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld64_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,batch_eq_16)822*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, batch_eq_16) {
823*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
824*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
825*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
826*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
827*4bdc9457SAndroid Build Coastguard Worker }
828*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,batch_div_16)829*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, batch_div_16) {
830*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
831*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
832*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
833*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
834*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
835*4bdc9457SAndroid Build Coastguard Worker }
836*4bdc9457SAndroid Build Coastguard Worker }
837*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,batch_lt_16)838*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, batch_lt_16) {
839*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
840*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
841*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
842*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
843*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
844*4bdc9457SAndroid Build Coastguard Worker }
845*4bdc9457SAndroid Build Coastguard Worker }
846*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,batch_gt_16)847*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, batch_gt_16) {
848*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
849*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
850*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
851*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
852*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
853*4bdc9457SAndroid Build Coastguard Worker }
854*4bdc9457SAndroid Build Coastguard Worker }
855*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,inplace_a)856*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, inplace_a) {
857*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
858*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
859*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
860*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
861*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
862*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
863*4bdc9457SAndroid Build Coastguard Worker }
864*4bdc9457SAndroid Build Coastguard Worker }
865*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,inplace_b)866*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, inplace_b) {
867*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
868*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
869*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
870*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
871*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
872*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
873*4bdc9457SAndroid Build Coastguard Worker }
874*4bdc9457SAndroid Build Coastguard Worker }
875*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,inplace_a_and_b)876*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, inplace_a_and_b) {
877*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
878*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
879*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
884*4bdc9457SAndroid Build Coastguard Worker }
885*4bdc9457SAndroid Build Coastguard Worker }
886*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,a_zero_point)887*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, a_zero_point) {
888*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
889*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker }
897*4bdc9457SAndroid Build Coastguard Worker }
898*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,b_zero_point)899*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, b_zero_point) {
900*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
901*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
907*4bdc9457SAndroid Build Coastguard Worker }
908*4bdc9457SAndroid Build Coastguard Worker }
909*4bdc9457SAndroid Build Coastguard Worker }
910*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,y_zero_point)911*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, y_zero_point) {
912*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
913*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
919*4bdc9457SAndroid Build Coastguard Worker }
920*4bdc9457SAndroid Build Coastguard Worker }
921*4bdc9457SAndroid Build Coastguard Worker }
922*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,a_scale)923*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, a_scale) {
924*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
925*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
926*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
927*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
931*4bdc9457SAndroid Build Coastguard Worker }
932*4bdc9457SAndroid Build Coastguard Worker }
933*4bdc9457SAndroid Build Coastguard Worker }
934*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,b_scale)935*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, b_scale) {
936*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
937*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
938*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
939*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
943*4bdc9457SAndroid Build Coastguard Worker }
944*4bdc9457SAndroid Build Coastguard Worker }
945*4bdc9457SAndroid Build Coastguard Worker }
946*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,y_scale)947*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, y_scale) {
948*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
949*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
950*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
951*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
955*4bdc9457SAndroid Build Coastguard Worker }
956*4bdc9457SAndroid Build Coastguard Worker }
957*4bdc9457SAndroid Build Coastguard Worker }
958*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,qmin)959*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, qmin) {
960*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
961*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
962*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
963*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
964*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
965*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
966*4bdc9457SAndroid Build Coastguard Worker }
967*4bdc9457SAndroid Build Coastguard Worker }
968*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16,qmax)969*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__NEONV8_LD128_X16, qmax) {
970*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_V8;
971*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
972*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
973*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
974*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
975*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__neonv8_ld128_x16, xnn_init_qu8_mul_minmax_fp32_neonv8_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,batch_eq_8)982*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8, batch_eq_8) {
983*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
984*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
985*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
986*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
987*4bdc9457SAndroid Build Coastguard Worker }
988*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,batch_div_8)989*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
993*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
994*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
995*4bdc9457SAndroid Build Coastguard Worker }
996*4bdc9457SAndroid Build Coastguard Worker }
997*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,batch_lt_8)998*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1002*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1003*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1004*4bdc9457SAndroid Build Coastguard Worker }
1005*4bdc9457SAndroid Build Coastguard Worker }
1006*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,batch_gt_8)1007*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1011*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1012*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1013*4bdc9457SAndroid Build Coastguard Worker }
1014*4bdc9457SAndroid Build Coastguard Worker }
1015*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,inplace_a)1016*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1020*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1021*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1022*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1023*4bdc9457SAndroid Build Coastguard Worker }
1024*4bdc9457SAndroid Build Coastguard Worker }
1025*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,inplace_b)1026*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1030*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1031*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1032*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1033*4bdc9457SAndroid Build Coastguard Worker }
1034*4bdc9457SAndroid Build Coastguard Worker }
1035*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,inplace_a_and_b)1036*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1044*4bdc9457SAndroid Build Coastguard Worker }
1045*4bdc9457SAndroid Build Coastguard Worker }
1046*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,a_zero_point)1047*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1055*4bdc9457SAndroid Build Coastguard Worker }
1056*4bdc9457SAndroid Build Coastguard Worker }
1057*4bdc9457SAndroid Build Coastguard Worker }
1058*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,b_zero_point)1059*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1067*4bdc9457SAndroid Build Coastguard Worker }
1068*4bdc9457SAndroid Build Coastguard Worker }
1069*4bdc9457SAndroid Build Coastguard Worker }
1070*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,y_zero_point)1071*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1079*4bdc9457SAndroid Build Coastguard Worker }
1080*4bdc9457SAndroid Build Coastguard Worker }
1081*4bdc9457SAndroid Build Coastguard Worker }
1082*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,a_scale)1083*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1091*4bdc9457SAndroid Build Coastguard Worker }
1092*4bdc9457SAndroid Build Coastguard Worker }
1093*4bdc9457SAndroid Build Coastguard Worker }
1094*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,b_scale)1095*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1103*4bdc9457SAndroid Build Coastguard Worker }
1104*4bdc9457SAndroid Build Coastguard Worker }
1105*4bdc9457SAndroid Build Coastguard Worker }
1106*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,y_scale)1107*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1115*4bdc9457SAndroid Build Coastguard Worker }
1116*4bdc9457SAndroid Build Coastguard Worker }
1117*4bdc9457SAndroid Build Coastguard Worker }
1118*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,qmin)1119*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1123*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1124*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1125*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1126*4bdc9457SAndroid Build Coastguard Worker }
1127*4bdc9457SAndroid Build Coastguard Worker }
1128*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X8,qmax)1129*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1133*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1134*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1135*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,batch_eq_16)1142*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16, batch_eq_16) {
1143*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1144*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1145*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1146*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1147*4bdc9457SAndroid Build Coastguard Worker }
1148*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,batch_div_16)1149*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1153*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1154*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1155*4bdc9457SAndroid Build Coastguard Worker }
1156*4bdc9457SAndroid Build Coastguard Worker }
1157*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,batch_lt_16)1158*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1162*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1163*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1164*4bdc9457SAndroid Build Coastguard Worker }
1165*4bdc9457SAndroid Build Coastguard Worker }
1166*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,batch_gt_16)1167*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1171*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1172*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1173*4bdc9457SAndroid Build Coastguard Worker }
1174*4bdc9457SAndroid Build Coastguard Worker }
1175*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,inplace_a)1176*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1180*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1181*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1182*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1183*4bdc9457SAndroid Build Coastguard Worker }
1184*4bdc9457SAndroid Build Coastguard Worker }
1185*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,inplace_b)1186*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1190*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1191*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1192*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1193*4bdc9457SAndroid Build Coastguard Worker }
1194*4bdc9457SAndroid Build Coastguard Worker }
1195*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,inplace_a_and_b)1196*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1204*4bdc9457SAndroid Build Coastguard Worker }
1205*4bdc9457SAndroid Build Coastguard Worker }
1206*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,a_zero_point)1207*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1215*4bdc9457SAndroid Build Coastguard Worker }
1216*4bdc9457SAndroid Build Coastguard Worker }
1217*4bdc9457SAndroid Build Coastguard Worker }
1218*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,b_zero_point)1219*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker }
1229*4bdc9457SAndroid Build Coastguard Worker }
1230*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,y_zero_point)1231*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1239*4bdc9457SAndroid Build Coastguard Worker }
1240*4bdc9457SAndroid Build Coastguard Worker }
1241*4bdc9457SAndroid Build Coastguard Worker }
1242*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,a_scale)1243*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1251*4bdc9457SAndroid Build Coastguard Worker }
1252*4bdc9457SAndroid Build Coastguard Worker }
1253*4bdc9457SAndroid Build Coastguard Worker }
1254*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,b_scale)1255*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1263*4bdc9457SAndroid Build Coastguard Worker }
1264*4bdc9457SAndroid Build Coastguard Worker }
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,y_scale)1267*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1275*4bdc9457SAndroid Build Coastguard Worker }
1276*4bdc9457SAndroid Build Coastguard Worker }
1277*4bdc9457SAndroid Build Coastguard Worker }
1278*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,qmin)1279*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1283*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1284*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1285*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1286*4bdc9457SAndroid Build Coastguard Worker }
1287*4bdc9457SAndroid Build Coastguard Worker }
1288*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE2_MUL16_LD64_X16,qmax)1289*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__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 VMulMicrokernelTester()
1293*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1294*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1295*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse2_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,batch_eq_8)1302*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, batch_eq_8) {
1303*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1304*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1305*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1306*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1307*4bdc9457SAndroid Build Coastguard Worker }
1308*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,batch_div_8)1309*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, batch_div_8) {
1310*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1311*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1312*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1313*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1314*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1315*4bdc9457SAndroid Build Coastguard Worker }
1316*4bdc9457SAndroid Build Coastguard Worker }
1317*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,batch_lt_8)1318*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, batch_lt_8) {
1319*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1320*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
1321*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1322*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1324*4bdc9457SAndroid Build Coastguard Worker }
1325*4bdc9457SAndroid Build Coastguard Worker }
1326*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,batch_gt_8)1327*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, batch_gt_8) {
1328*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1329*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1330*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1331*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1332*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1333*4bdc9457SAndroid Build Coastguard Worker }
1334*4bdc9457SAndroid Build Coastguard Worker }
1335*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,inplace_a)1336*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, inplace_a) {
1337*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1338*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1339*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1340*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1341*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1342*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1343*4bdc9457SAndroid Build Coastguard Worker }
1344*4bdc9457SAndroid Build Coastguard Worker }
1345*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,inplace_b)1346*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, inplace_b) {
1347*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1348*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1349*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1350*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1351*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1352*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1353*4bdc9457SAndroid Build Coastguard Worker }
1354*4bdc9457SAndroid Build Coastguard Worker }
1355*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,inplace_a_and_b)1356*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, inplace_a_and_b) {
1357*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1358*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1359*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1364*4bdc9457SAndroid Build Coastguard Worker }
1365*4bdc9457SAndroid Build Coastguard Worker }
1366*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,a_zero_point)1367*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, a_zero_point) {
1368*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1369*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1375*4bdc9457SAndroid Build Coastguard Worker }
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker }
1378*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,b_zero_point)1379*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, b_zero_point) {
1380*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1381*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1387*4bdc9457SAndroid Build Coastguard Worker }
1388*4bdc9457SAndroid Build Coastguard Worker }
1389*4bdc9457SAndroid Build Coastguard Worker }
1390*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,y_zero_point)1391*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, y_zero_point) {
1392*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1393*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1399*4bdc9457SAndroid Build Coastguard Worker }
1400*4bdc9457SAndroid Build Coastguard Worker }
1401*4bdc9457SAndroid Build Coastguard Worker }
1402*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,a_scale)1403*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, a_scale) {
1404*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1405*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1406*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
1407*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1411*4bdc9457SAndroid Build Coastguard Worker }
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,b_scale)1415*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, b_scale) {
1416*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1417*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1418*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
1419*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1423*4bdc9457SAndroid Build Coastguard Worker }
1424*4bdc9457SAndroid Build Coastguard Worker }
1425*4bdc9457SAndroid Build Coastguard Worker }
1426*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,y_scale)1427*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, y_scale) {
1428*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1429*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1430*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
1431*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1435*4bdc9457SAndroid Build Coastguard Worker }
1436*4bdc9457SAndroid Build Coastguard Worker }
1437*4bdc9457SAndroid Build Coastguard Worker }
1438*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,qmin)1439*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, qmin) {
1440*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1441*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1442*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1443*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1444*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1445*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1446*4bdc9457SAndroid Build Coastguard Worker }
1447*4bdc9457SAndroid Build Coastguard Worker }
1448*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8,qmax)1449*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X8, qmax) {
1450*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1451*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1452*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1453*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1454*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1455*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,batch_eq_16)1462*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, batch_eq_16) {
1463*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1464*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1465*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1466*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1467*4bdc9457SAndroid Build Coastguard Worker }
1468*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,batch_div_16)1469*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, batch_div_16) {
1470*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1471*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
1472*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1473*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1474*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1475*4bdc9457SAndroid Build Coastguard Worker }
1476*4bdc9457SAndroid Build Coastguard Worker }
1477*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,batch_lt_16)1478*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, batch_lt_16) {
1479*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1480*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
1481*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1482*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1483*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1484*4bdc9457SAndroid Build Coastguard Worker }
1485*4bdc9457SAndroid Build Coastguard Worker }
1486*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,batch_gt_16)1487*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, batch_gt_16) {
1488*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1489*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1490*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1491*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1492*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1493*4bdc9457SAndroid Build Coastguard Worker }
1494*4bdc9457SAndroid Build Coastguard Worker }
1495*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,inplace_a)1496*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, inplace_a) {
1497*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1498*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1499*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1500*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1501*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1503*4bdc9457SAndroid Build Coastguard Worker }
1504*4bdc9457SAndroid Build Coastguard Worker }
1505*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,inplace_b)1506*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, inplace_b) {
1507*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1508*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1509*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1510*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1511*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1512*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1513*4bdc9457SAndroid Build Coastguard Worker }
1514*4bdc9457SAndroid Build Coastguard Worker }
1515*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,inplace_a_and_b)1516*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, inplace_a_and_b) {
1517*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1518*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1519*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1524*4bdc9457SAndroid Build Coastguard Worker }
1525*4bdc9457SAndroid Build Coastguard Worker }
1526*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,a_zero_point)1527*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, a_zero_point) {
1528*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1529*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1535*4bdc9457SAndroid Build Coastguard Worker }
1536*4bdc9457SAndroid Build Coastguard Worker }
1537*4bdc9457SAndroid Build Coastguard Worker }
1538*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,b_zero_point)1539*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, b_zero_point) {
1540*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1541*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1547*4bdc9457SAndroid Build Coastguard Worker }
1548*4bdc9457SAndroid Build Coastguard Worker }
1549*4bdc9457SAndroid Build Coastguard Worker }
1550*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,y_zero_point)1551*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, y_zero_point) {
1552*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1553*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1559*4bdc9457SAndroid Build Coastguard Worker }
1560*4bdc9457SAndroid Build Coastguard Worker }
1561*4bdc9457SAndroid Build Coastguard Worker }
1562*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,a_scale)1563*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, a_scale) {
1564*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1565*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1566*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
1567*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1571*4bdc9457SAndroid Build Coastguard Worker }
1572*4bdc9457SAndroid Build Coastguard Worker }
1573*4bdc9457SAndroid Build Coastguard Worker }
1574*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,b_scale)1575*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, b_scale) {
1576*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1577*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1578*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
1579*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1583*4bdc9457SAndroid Build Coastguard Worker }
1584*4bdc9457SAndroid Build Coastguard Worker }
1585*4bdc9457SAndroid Build Coastguard Worker }
1586*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,y_scale)1587*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, y_scale) {
1588*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1589*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1590*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
1591*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1595*4bdc9457SAndroid Build Coastguard Worker }
1596*4bdc9457SAndroid Build Coastguard Worker }
1597*4bdc9457SAndroid Build Coastguard Worker }
1598*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,qmin)1599*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, qmin) {
1600*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1601*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1602*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1603*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1604*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1606*4bdc9457SAndroid Build Coastguard Worker }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16,qmax)1609*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SSE41_MUL16_LD64_X16, qmax) {
1610*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1611*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1612*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1613*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1614*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1615*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__sse41_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,batch_eq_8)1622*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, batch_eq_8) {
1623*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1624*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1625*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1626*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1627*4bdc9457SAndroid Build Coastguard Worker }
1628*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,batch_div_8)1629*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, batch_div_8) {
1630*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1631*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1632*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1633*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1635*4bdc9457SAndroid Build Coastguard Worker }
1636*4bdc9457SAndroid Build Coastguard Worker }
1637*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,batch_lt_8)1638*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, batch_lt_8) {
1639*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1640*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
1641*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1642*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1643*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1644*4bdc9457SAndroid Build Coastguard Worker }
1645*4bdc9457SAndroid Build Coastguard Worker }
1646*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,batch_gt_8)1647*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, batch_gt_8) {
1648*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1649*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1650*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1651*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1652*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1653*4bdc9457SAndroid Build Coastguard Worker }
1654*4bdc9457SAndroid Build Coastguard Worker }
1655*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,inplace_a)1656*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, inplace_a) {
1657*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1658*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1659*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1660*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1661*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1662*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1663*4bdc9457SAndroid Build Coastguard Worker }
1664*4bdc9457SAndroid Build Coastguard Worker }
1665*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,inplace_b)1666*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, inplace_b) {
1667*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1668*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1669*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1670*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1671*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1672*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1673*4bdc9457SAndroid Build Coastguard Worker }
1674*4bdc9457SAndroid Build Coastguard Worker }
1675*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,inplace_a_and_b)1676*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, inplace_a_and_b) {
1677*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1678*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1679*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1684*4bdc9457SAndroid Build Coastguard Worker }
1685*4bdc9457SAndroid Build Coastguard Worker }
1686*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,a_zero_point)1687*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, a_zero_point) {
1688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1695*4bdc9457SAndroid Build Coastguard Worker }
1696*4bdc9457SAndroid Build Coastguard Worker }
1697*4bdc9457SAndroid Build Coastguard Worker }
1698*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,b_zero_point)1699*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, b_zero_point) {
1700*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1707*4bdc9457SAndroid Build Coastguard Worker }
1708*4bdc9457SAndroid Build Coastguard Worker }
1709*4bdc9457SAndroid Build Coastguard Worker }
1710*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,y_zero_point)1711*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, y_zero_point) {
1712*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1719*4bdc9457SAndroid Build Coastguard Worker }
1720*4bdc9457SAndroid Build Coastguard Worker }
1721*4bdc9457SAndroid Build Coastguard Worker }
1722*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,a_scale)1723*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, a_scale) {
1724*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1731*4bdc9457SAndroid Build Coastguard Worker }
1732*4bdc9457SAndroid Build Coastguard Worker }
1733*4bdc9457SAndroid Build Coastguard Worker }
1734*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,b_scale)1735*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, b_scale) {
1736*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1743*4bdc9457SAndroid Build Coastguard Worker }
1744*4bdc9457SAndroid Build Coastguard Worker }
1745*4bdc9457SAndroid Build Coastguard Worker }
1746*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,y_scale)1747*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, y_scale) {
1748*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1755*4bdc9457SAndroid Build Coastguard Worker }
1756*4bdc9457SAndroid Build Coastguard Worker }
1757*4bdc9457SAndroid Build Coastguard Worker }
1758*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,qmin)1759*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, qmin) {
1760*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1761*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1762*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1763*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1764*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1765*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1766*4bdc9457SAndroid Build Coastguard Worker }
1767*4bdc9457SAndroid Build Coastguard Worker }
1768*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8,qmax)1769*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X8, qmax) {
1770*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1771*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1772*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1773*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1774*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1775*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x8, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,batch_eq_16)1782*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, batch_eq_16) {
1783*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1784*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1785*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1786*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1787*4bdc9457SAndroid Build Coastguard Worker }
1788*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,batch_div_16)1789*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, batch_div_16) {
1790*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1791*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
1792*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1793*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1794*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1795*4bdc9457SAndroid Build Coastguard Worker }
1796*4bdc9457SAndroid Build Coastguard Worker }
1797*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,batch_lt_16)1798*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, batch_lt_16) {
1799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1800*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
1801*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1802*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1803*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1804*4bdc9457SAndroid Build Coastguard Worker }
1805*4bdc9457SAndroid Build Coastguard Worker }
1806*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,batch_gt_16)1807*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, batch_gt_16) {
1808*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1809*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1810*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1811*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1812*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1813*4bdc9457SAndroid Build Coastguard Worker }
1814*4bdc9457SAndroid Build Coastguard Worker }
1815*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,inplace_a)1816*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, inplace_a) {
1817*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1818*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1819*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1820*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1821*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1822*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1823*4bdc9457SAndroid Build Coastguard Worker }
1824*4bdc9457SAndroid Build Coastguard Worker }
1825*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,inplace_b)1826*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, inplace_b) {
1827*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1828*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1829*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1830*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1831*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1832*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1833*4bdc9457SAndroid Build Coastguard Worker }
1834*4bdc9457SAndroid Build Coastguard Worker }
1835*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,inplace_a_and_b)1836*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, inplace_a_and_b) {
1837*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1838*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1839*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1844*4bdc9457SAndroid Build Coastguard Worker }
1845*4bdc9457SAndroid Build Coastguard Worker }
1846*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,a_zero_point)1847*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, a_zero_point) {
1848*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1855*4bdc9457SAndroid Build Coastguard Worker }
1856*4bdc9457SAndroid Build Coastguard Worker }
1857*4bdc9457SAndroid Build Coastguard Worker }
1858*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,b_zero_point)1859*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, b_zero_point) {
1860*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1867*4bdc9457SAndroid Build Coastguard Worker }
1868*4bdc9457SAndroid Build Coastguard Worker }
1869*4bdc9457SAndroid Build Coastguard Worker }
1870*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,y_zero_point)1871*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, y_zero_point) {
1872*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1879*4bdc9457SAndroid Build Coastguard Worker }
1880*4bdc9457SAndroid Build Coastguard Worker }
1881*4bdc9457SAndroid Build Coastguard Worker }
1882*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,a_scale)1883*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, a_scale) {
1884*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1891*4bdc9457SAndroid Build Coastguard Worker }
1892*4bdc9457SAndroid Build Coastguard Worker }
1893*4bdc9457SAndroid Build Coastguard Worker }
1894*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,b_scale)1895*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, b_scale) {
1896*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1903*4bdc9457SAndroid Build Coastguard Worker }
1904*4bdc9457SAndroid Build Coastguard Worker }
1905*4bdc9457SAndroid Build Coastguard Worker }
1906*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,y_scale)1907*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, y_scale) {
1908*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
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 VMulMicrokernelTester()
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_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1915*4bdc9457SAndroid Build Coastguard Worker }
1916*4bdc9457SAndroid Build Coastguard Worker }
1917*4bdc9457SAndroid Build Coastguard Worker }
1918*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,qmin)1919*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, qmin) {
1920*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1921*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1922*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1923*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1924*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
1925*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
1926*4bdc9457SAndroid Build Coastguard Worker }
1927*4bdc9457SAndroid Build Coastguard Worker }
1928*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16,qmax)1929*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__AVX_MUL16_LD64_X16, qmax) {
1930*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
1931*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1932*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1933*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1934*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
1935*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__avx_mul16_ld64_x16, xnn_init_qu8_mul_minmax_fp32_sse2_params, xnn_qu8_requantize_fp32);
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_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,batch_eq_8)1942*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, batch_eq_8) {
1943*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1944*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1945*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1946*4bdc9457SAndroid Build Coastguard Worker }
1947*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,batch_div_8)1948*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, batch_div_8) {
1949*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1950*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1951*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1952*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1953*4bdc9457SAndroid Build Coastguard Worker }
1954*4bdc9457SAndroid Build Coastguard Worker }
1955*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,batch_lt_8)1956*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, batch_lt_8) {
1957*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
1958*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1959*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1960*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1961*4bdc9457SAndroid Build Coastguard Worker }
1962*4bdc9457SAndroid Build Coastguard Worker }
1963*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,batch_gt_8)1964*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, batch_gt_8) {
1965*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1966*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1967*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1968*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1969*4bdc9457SAndroid Build Coastguard Worker }
1970*4bdc9457SAndroid Build Coastguard Worker }
1971*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,inplace_a)1972*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, inplace_a) {
1973*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1974*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1975*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1976*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1977*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1978*4bdc9457SAndroid Build Coastguard Worker }
1979*4bdc9457SAndroid Build Coastguard Worker }
1980*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,inplace_b)1981*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, inplace_b) {
1982*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1983*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1984*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1985*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1986*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1987*4bdc9457SAndroid Build Coastguard Worker }
1988*4bdc9457SAndroid Build Coastguard Worker }
1989*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,inplace_a_and_b)1990*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, inplace_a_and_b) {
1991*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1992*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
1993*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1994*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
1995*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
1996*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
1997*4bdc9457SAndroid Build Coastguard Worker }
1998*4bdc9457SAndroid Build Coastguard Worker }
1999*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,a_zero_point)2000*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, a_zero_point) {
2001*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2002*4bdc9457SAndroid Build Coastguard Worker for (int32_t a_zero_point = -128; a_zero_point <= 127; a_zero_point += 51) {
2003*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2004*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2005*4bdc9457SAndroid Build Coastguard Worker .a_zero_point(a_zero_point)
2006*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2007*4bdc9457SAndroid Build Coastguard Worker }
2008*4bdc9457SAndroid Build Coastguard Worker }
2009*4bdc9457SAndroid Build Coastguard Worker }
2010*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,b_zero_point)2011*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, b_zero_point) {
2012*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2013*4bdc9457SAndroid Build Coastguard Worker for (int32_t b_zero_point = -128; b_zero_point <= 127; b_zero_point += 51) {
2014*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2015*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2016*4bdc9457SAndroid Build Coastguard Worker .b_zero_point(b_zero_point)
2017*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2018*4bdc9457SAndroid Build Coastguard Worker }
2019*4bdc9457SAndroid Build Coastguard Worker }
2020*4bdc9457SAndroid Build Coastguard Worker }
2021*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,y_zero_point)2022*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, y_zero_point) {
2023*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2024*4bdc9457SAndroid Build Coastguard Worker for (int32_t y_zero_point = -128; y_zero_point <= 127; y_zero_point += 51) {
2025*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2026*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2027*4bdc9457SAndroid Build Coastguard Worker .y_zero_point(y_zero_point)
2028*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2029*4bdc9457SAndroid Build Coastguard Worker }
2030*4bdc9457SAndroid Build Coastguard Worker }
2031*4bdc9457SAndroid Build Coastguard Worker }
2032*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,a_scale)2033*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, a_scale) {
2034*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2035*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
2036*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2037*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2038*4bdc9457SAndroid Build Coastguard Worker .a_scale(a_scale)
2039*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2040*4bdc9457SAndroid Build Coastguard Worker }
2041*4bdc9457SAndroid Build Coastguard Worker }
2042*4bdc9457SAndroid Build Coastguard Worker }
2043*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,b_scale)2044*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, b_scale) {
2045*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2046*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
2047*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2048*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2049*4bdc9457SAndroid Build Coastguard Worker .b_scale(b_scale)
2050*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2051*4bdc9457SAndroid Build Coastguard Worker }
2052*4bdc9457SAndroid Build Coastguard Worker }
2053*4bdc9457SAndroid Build Coastguard Worker }
2054*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,y_scale)2055*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, y_scale) {
2056*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2057*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
2058*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2059*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2060*4bdc9457SAndroid Build Coastguard Worker .y_scale(y_scale)
2061*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2062*4bdc9457SAndroid Build Coastguard Worker }
2063*4bdc9457SAndroid Build Coastguard Worker }
2064*4bdc9457SAndroid Build Coastguard Worker }
2065*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,qmin)2066*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, qmin) {
2067*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2068*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2069*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2070*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2071*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2072*4bdc9457SAndroid Build Coastguard Worker }
2073*4bdc9457SAndroid Build Coastguard Worker }
2074*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8,qmax)2075*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X8, qmax) {
2076*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2077*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2078*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2079*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x8, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2081*4bdc9457SAndroid Build Coastguard Worker }
2082*4bdc9457SAndroid Build Coastguard Worker }
2083*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2084*4bdc9457SAndroid Build Coastguard Worker
2085*4bdc9457SAndroid Build Coastguard Worker
2086*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,batch_eq_16)2087*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, batch_eq_16) {
2088*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2089*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
2090*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2091*4bdc9457SAndroid Build Coastguard Worker }
2092*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,batch_div_16)2093*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, batch_div_16) {
2094*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
2095*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2096*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2097*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2098*4bdc9457SAndroid Build Coastguard Worker }
2099*4bdc9457SAndroid Build Coastguard Worker }
2100*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,batch_lt_16)2101*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, batch_lt_16) {
2102*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
2103*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2104*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2105*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2106*4bdc9457SAndroid Build Coastguard Worker }
2107*4bdc9457SAndroid Build Coastguard Worker }
2108*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,batch_gt_16)2109*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, batch_gt_16) {
2110*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
2111*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2112*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2113*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2114*4bdc9457SAndroid Build Coastguard Worker }
2115*4bdc9457SAndroid Build Coastguard Worker }
2116*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,inplace_a)2117*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, inplace_a) {
2118*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2119*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2120*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2121*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2122*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2123*4bdc9457SAndroid Build Coastguard Worker }
2124*4bdc9457SAndroid Build Coastguard Worker }
2125*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,inplace_b)2126*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, inplace_b) {
2127*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2128*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2129*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2130*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2131*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2132*4bdc9457SAndroid Build Coastguard Worker }
2133*4bdc9457SAndroid Build Coastguard Worker }
2134*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,inplace_a_and_b)2135*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, inplace_a_and_b) {
2136*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2137*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2138*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2139*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2140*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2141*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2142*4bdc9457SAndroid Build Coastguard Worker }
2143*4bdc9457SAndroid Build Coastguard Worker }
2144*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,a_zero_point)2145*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, a_zero_point) {
2146*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2147*4bdc9457SAndroid Build Coastguard Worker for (int32_t a_zero_point = -128; a_zero_point <= 127; a_zero_point += 51) {
2148*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2149*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2150*4bdc9457SAndroid Build Coastguard Worker .a_zero_point(a_zero_point)
2151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2152*4bdc9457SAndroid Build Coastguard Worker }
2153*4bdc9457SAndroid Build Coastguard Worker }
2154*4bdc9457SAndroid Build Coastguard Worker }
2155*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,b_zero_point)2156*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, b_zero_point) {
2157*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2158*4bdc9457SAndroid Build Coastguard Worker for (int32_t b_zero_point = -128; b_zero_point <= 127; b_zero_point += 51) {
2159*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2160*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2161*4bdc9457SAndroid Build Coastguard Worker .b_zero_point(b_zero_point)
2162*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2163*4bdc9457SAndroid Build Coastguard Worker }
2164*4bdc9457SAndroid Build Coastguard Worker }
2165*4bdc9457SAndroid Build Coastguard Worker }
2166*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,y_zero_point)2167*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, y_zero_point) {
2168*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2169*4bdc9457SAndroid Build Coastguard Worker for (int32_t y_zero_point = -128; y_zero_point <= 127; y_zero_point += 51) {
2170*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2171*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2172*4bdc9457SAndroid Build Coastguard Worker .y_zero_point(y_zero_point)
2173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2174*4bdc9457SAndroid Build Coastguard Worker }
2175*4bdc9457SAndroid Build Coastguard Worker }
2176*4bdc9457SAndroid Build Coastguard Worker }
2177*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,a_scale)2178*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, a_scale) {
2179*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2180*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
2181*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2182*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2183*4bdc9457SAndroid Build Coastguard Worker .a_scale(a_scale)
2184*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2185*4bdc9457SAndroid Build Coastguard Worker }
2186*4bdc9457SAndroid Build Coastguard Worker }
2187*4bdc9457SAndroid Build Coastguard Worker }
2188*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,b_scale)2189*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, b_scale) {
2190*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2191*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
2192*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2193*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2194*4bdc9457SAndroid Build Coastguard Worker .b_scale(b_scale)
2195*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2196*4bdc9457SAndroid Build Coastguard Worker }
2197*4bdc9457SAndroid Build Coastguard Worker }
2198*4bdc9457SAndroid Build Coastguard Worker }
2199*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,y_scale)2200*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, y_scale) {
2201*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2202*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
2203*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2204*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2205*4bdc9457SAndroid Build Coastguard Worker .y_scale(y_scale)
2206*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2207*4bdc9457SAndroid Build Coastguard Worker }
2208*4bdc9457SAndroid Build Coastguard Worker }
2209*4bdc9457SAndroid Build Coastguard Worker }
2210*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,qmin)2211*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, qmin) {
2212*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2213*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2214*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2215*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2216*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2217*4bdc9457SAndroid Build Coastguard Worker }
2218*4bdc9457SAndroid Build Coastguard Worker }
2219*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16,qmax)2220*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__WASMSIMD_MUL32_LD64_X16, qmax) {
2221*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
2222*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2223*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2224*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2225*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__wasmsimd_mul32_ld64_x16, xnn_init_qu8_mul_minmax_fp32_wasmsimd_params, xnn_qu8_requantize_fp32);
2226*4bdc9457SAndroid Build Coastguard Worker }
2227*4bdc9457SAndroid Build Coastguard Worker }
2228*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
2229*4bdc9457SAndroid Build Coastguard Worker
2230*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,batch_eq_1)2231*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, batch_eq_1) {
2232*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2233*4bdc9457SAndroid Build Coastguard Worker .batch_size(1)
2234*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2235*4bdc9457SAndroid Build Coastguard Worker }
2236*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,batch_gt_1)2237*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, batch_gt_1) {
2238*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 2; batch_size < 10; batch_size++) {
2239*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2240*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2241*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2242*4bdc9457SAndroid Build Coastguard Worker }
2243*4bdc9457SAndroid Build Coastguard Worker }
2244*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,inplace_a)2245*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, inplace_a) {
2246*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2247*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2248*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2249*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2250*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2251*4bdc9457SAndroid Build Coastguard Worker }
2252*4bdc9457SAndroid Build Coastguard Worker }
2253*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,inplace_b)2254*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, inplace_b) {
2255*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2256*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2257*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2258*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2259*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2260*4bdc9457SAndroid Build Coastguard Worker }
2261*4bdc9457SAndroid Build Coastguard Worker }
2262*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,inplace_a_and_b)2263*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, inplace_a_and_b) {
2264*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2265*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2266*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2267*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2268*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2269*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2270*4bdc9457SAndroid Build Coastguard Worker }
2271*4bdc9457SAndroid Build Coastguard Worker }
2272*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,a_zero_point)2273*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, a_zero_point) {
2274*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2275*4bdc9457SAndroid Build Coastguard Worker for (int32_t a_zero_point = -128; a_zero_point <= 127; a_zero_point += 51) {
2276*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2277*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2278*4bdc9457SAndroid Build Coastguard Worker .a_zero_point(a_zero_point)
2279*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2280*4bdc9457SAndroid Build Coastguard Worker }
2281*4bdc9457SAndroid Build Coastguard Worker }
2282*4bdc9457SAndroid Build Coastguard Worker }
2283*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,b_zero_point)2284*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, b_zero_point) {
2285*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2286*4bdc9457SAndroid Build Coastguard Worker for (int32_t b_zero_point = -128; b_zero_point <= 127; b_zero_point += 51) {
2287*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2288*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2289*4bdc9457SAndroid Build Coastguard Worker .b_zero_point(b_zero_point)
2290*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2291*4bdc9457SAndroid Build Coastguard Worker }
2292*4bdc9457SAndroid Build Coastguard Worker }
2293*4bdc9457SAndroid Build Coastguard Worker }
2294*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,y_zero_point)2295*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, y_zero_point) {
2296*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2297*4bdc9457SAndroid Build Coastguard Worker for (int32_t y_zero_point = -128; y_zero_point <= 127; y_zero_point += 51) {
2298*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2299*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2300*4bdc9457SAndroid Build Coastguard Worker .y_zero_point(y_zero_point)
2301*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2302*4bdc9457SAndroid Build Coastguard Worker }
2303*4bdc9457SAndroid Build Coastguard Worker }
2304*4bdc9457SAndroid Build Coastguard Worker }
2305*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,a_scale)2306*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, a_scale) {
2307*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2308*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
2309*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2310*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2311*4bdc9457SAndroid Build Coastguard Worker .a_scale(a_scale)
2312*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2313*4bdc9457SAndroid Build Coastguard Worker }
2314*4bdc9457SAndroid Build Coastguard Worker }
2315*4bdc9457SAndroid Build Coastguard Worker }
2316*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,b_scale)2317*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, b_scale) {
2318*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2319*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
2320*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2321*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2322*4bdc9457SAndroid Build Coastguard Worker .b_scale(b_scale)
2323*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2324*4bdc9457SAndroid Build Coastguard Worker }
2325*4bdc9457SAndroid Build Coastguard Worker }
2326*4bdc9457SAndroid Build Coastguard Worker }
2327*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,y_scale)2328*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, y_scale) {
2329*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2330*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
2331*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2332*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2333*4bdc9457SAndroid Build Coastguard Worker .y_scale(y_scale)
2334*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2335*4bdc9457SAndroid Build Coastguard Worker }
2336*4bdc9457SAndroid Build Coastguard Worker }
2337*4bdc9457SAndroid Build Coastguard Worker }
2338*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,qmin)2339*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, qmin) {
2340*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2341*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2342*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2343*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2344*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2345*4bdc9457SAndroid Build Coastguard Worker }
2346*4bdc9457SAndroid Build Coastguard Worker }
2347*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1,qmax)2348*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X1, qmax) {
2349*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2350*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2351*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2352*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2353*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x1, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2354*4bdc9457SAndroid Build Coastguard Worker }
2355*4bdc9457SAndroid Build Coastguard Worker }
2356*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,batch_eq_2)2357*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, batch_eq_2) {
2358*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2359*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2360*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2361*4bdc9457SAndroid Build Coastguard Worker }
2362*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,batch_div_2)2363*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, batch_div_2) {
2364*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 4; batch_size < 20; batch_size += 2) {
2365*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2366*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2367*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2368*4bdc9457SAndroid Build Coastguard Worker }
2369*4bdc9457SAndroid Build Coastguard Worker }
2370*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,batch_lt_2)2371*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, batch_lt_2) {
2372*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 2; batch_size++) {
2373*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2374*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2375*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2376*4bdc9457SAndroid Build Coastguard Worker }
2377*4bdc9457SAndroid Build Coastguard Worker }
2378*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,batch_gt_2)2379*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, batch_gt_2) {
2380*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 3; batch_size < 4; batch_size++) {
2381*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2382*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2383*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2384*4bdc9457SAndroid Build Coastguard Worker }
2385*4bdc9457SAndroid Build Coastguard Worker }
2386*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,inplace_a)2387*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, inplace_a) {
2388*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2389*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2390*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2391*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2392*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2393*4bdc9457SAndroid Build Coastguard Worker }
2394*4bdc9457SAndroid Build Coastguard Worker }
2395*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,inplace_b)2396*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, inplace_b) {
2397*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2398*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2399*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2400*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2401*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2402*4bdc9457SAndroid Build Coastguard Worker }
2403*4bdc9457SAndroid Build Coastguard Worker }
2404*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,inplace_a_and_b)2405*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, inplace_a_and_b) {
2406*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2407*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2408*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2409*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2410*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2412*4bdc9457SAndroid Build Coastguard Worker }
2413*4bdc9457SAndroid Build Coastguard Worker }
2414*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,a_zero_point)2415*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, a_zero_point) {
2416*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2417*4bdc9457SAndroid Build Coastguard Worker for (int32_t a_zero_point = -128; a_zero_point <= 127; a_zero_point += 51) {
2418*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2419*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2420*4bdc9457SAndroid Build Coastguard Worker .a_zero_point(a_zero_point)
2421*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2422*4bdc9457SAndroid Build Coastguard Worker }
2423*4bdc9457SAndroid Build Coastguard Worker }
2424*4bdc9457SAndroid Build Coastguard Worker }
2425*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,b_zero_point)2426*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, b_zero_point) {
2427*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2428*4bdc9457SAndroid Build Coastguard Worker for (int32_t b_zero_point = -128; b_zero_point <= 127; b_zero_point += 51) {
2429*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2430*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2431*4bdc9457SAndroid Build Coastguard Worker .b_zero_point(b_zero_point)
2432*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2433*4bdc9457SAndroid Build Coastguard Worker }
2434*4bdc9457SAndroid Build Coastguard Worker }
2435*4bdc9457SAndroid Build Coastguard Worker }
2436*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,y_zero_point)2437*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, y_zero_point) {
2438*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2439*4bdc9457SAndroid Build Coastguard Worker for (int32_t y_zero_point = -128; y_zero_point <= 127; y_zero_point += 51) {
2440*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2441*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2442*4bdc9457SAndroid Build Coastguard Worker .y_zero_point(y_zero_point)
2443*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2444*4bdc9457SAndroid Build Coastguard Worker }
2445*4bdc9457SAndroid Build Coastguard Worker }
2446*4bdc9457SAndroid Build Coastguard Worker }
2447*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,a_scale)2448*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, a_scale) {
2449*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2450*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
2451*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2452*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2453*4bdc9457SAndroid Build Coastguard Worker .a_scale(a_scale)
2454*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2455*4bdc9457SAndroid Build Coastguard Worker }
2456*4bdc9457SAndroid Build Coastguard Worker }
2457*4bdc9457SAndroid Build Coastguard Worker }
2458*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,b_scale)2459*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, b_scale) {
2460*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2461*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
2462*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2463*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2464*4bdc9457SAndroid Build Coastguard Worker .b_scale(b_scale)
2465*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2466*4bdc9457SAndroid Build Coastguard Worker }
2467*4bdc9457SAndroid Build Coastguard Worker }
2468*4bdc9457SAndroid Build Coastguard Worker }
2469*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,y_scale)2470*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, y_scale) {
2471*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2472*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
2473*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2474*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2475*4bdc9457SAndroid Build Coastguard Worker .y_scale(y_scale)
2476*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2477*4bdc9457SAndroid Build Coastguard Worker }
2478*4bdc9457SAndroid Build Coastguard Worker }
2479*4bdc9457SAndroid Build Coastguard Worker }
2480*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,qmin)2481*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, qmin) {
2482*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2483*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2484*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2485*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2486*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2487*4bdc9457SAndroid Build Coastguard Worker }
2488*4bdc9457SAndroid Build Coastguard Worker }
2489*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2,qmax)2490*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X2, qmax) {
2491*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2492*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2493*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2494*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x2, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2496*4bdc9457SAndroid Build Coastguard Worker }
2497*4bdc9457SAndroid Build Coastguard Worker }
2498*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,batch_eq_4)2499*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, batch_eq_4) {
2500*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2501*4bdc9457SAndroid Build Coastguard Worker .batch_size(4)
2502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2503*4bdc9457SAndroid Build Coastguard Worker }
2504*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,batch_div_4)2505*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, batch_div_4) {
2506*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 8; batch_size < 40; batch_size += 4) {
2507*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2508*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2509*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2510*4bdc9457SAndroid Build Coastguard Worker }
2511*4bdc9457SAndroid Build Coastguard Worker }
2512*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,batch_lt_4)2513*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, batch_lt_4) {
2514*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 4; batch_size++) {
2515*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2516*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2517*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2518*4bdc9457SAndroid Build Coastguard Worker }
2519*4bdc9457SAndroid Build Coastguard Worker }
2520*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,batch_gt_4)2521*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, batch_gt_4) {
2522*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 5; batch_size < 8; batch_size++) {
2523*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2524*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2525*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2526*4bdc9457SAndroid Build Coastguard Worker }
2527*4bdc9457SAndroid Build Coastguard Worker }
2528*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,inplace_a)2529*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, inplace_a) {
2530*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2531*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2532*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2533*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2534*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2535*4bdc9457SAndroid Build Coastguard Worker }
2536*4bdc9457SAndroid Build Coastguard Worker }
2537*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,inplace_b)2538*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, inplace_b) {
2539*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2540*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2541*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2542*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2543*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2544*4bdc9457SAndroid Build Coastguard Worker }
2545*4bdc9457SAndroid Build Coastguard Worker }
2546*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,inplace_a_and_b)2547*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, inplace_a_and_b) {
2548*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2549*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2550*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2551*4bdc9457SAndroid Build Coastguard Worker .inplace_a(true)
2552*4bdc9457SAndroid Build Coastguard Worker .inplace_b(true)
2553*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2554*4bdc9457SAndroid Build Coastguard Worker }
2555*4bdc9457SAndroid Build Coastguard Worker }
2556*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,a_zero_point)2557*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, a_zero_point) {
2558*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2559*4bdc9457SAndroid Build Coastguard Worker for (int32_t a_zero_point = -128; a_zero_point <= 127; a_zero_point += 51) {
2560*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2561*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2562*4bdc9457SAndroid Build Coastguard Worker .a_zero_point(a_zero_point)
2563*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2564*4bdc9457SAndroid Build Coastguard Worker }
2565*4bdc9457SAndroid Build Coastguard Worker }
2566*4bdc9457SAndroid Build Coastguard Worker }
2567*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,b_zero_point)2568*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, b_zero_point) {
2569*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2570*4bdc9457SAndroid Build Coastguard Worker for (int32_t b_zero_point = -128; b_zero_point <= 127; b_zero_point += 51) {
2571*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2572*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2573*4bdc9457SAndroid Build Coastguard Worker .b_zero_point(b_zero_point)
2574*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2575*4bdc9457SAndroid Build Coastguard Worker }
2576*4bdc9457SAndroid Build Coastguard Worker }
2577*4bdc9457SAndroid Build Coastguard Worker }
2578*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,y_zero_point)2579*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, y_zero_point) {
2580*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2581*4bdc9457SAndroid Build Coastguard Worker for (int32_t y_zero_point = -128; y_zero_point <= 127; y_zero_point += 51) {
2582*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2583*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2584*4bdc9457SAndroid Build Coastguard Worker .y_zero_point(y_zero_point)
2585*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2586*4bdc9457SAndroid Build Coastguard Worker }
2587*4bdc9457SAndroid Build Coastguard Worker }
2588*4bdc9457SAndroid Build Coastguard Worker }
2589*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,a_scale)2590*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, a_scale) {
2591*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2592*4bdc9457SAndroid Build Coastguard Worker for (float a_scale = 0.1f; a_scale <= 10.0f; a_scale *= 3.14f) {
2593*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2594*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2595*4bdc9457SAndroid Build Coastguard Worker .a_scale(a_scale)
2596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2597*4bdc9457SAndroid Build Coastguard Worker }
2598*4bdc9457SAndroid Build Coastguard Worker }
2599*4bdc9457SAndroid Build Coastguard Worker }
2600*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,b_scale)2601*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, b_scale) {
2602*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2603*4bdc9457SAndroid Build Coastguard Worker for (float b_scale = 0.1f; b_scale <= 10.0f; b_scale *= 3.14f) {
2604*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2605*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2606*4bdc9457SAndroid Build Coastguard Worker .b_scale(b_scale)
2607*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2608*4bdc9457SAndroid Build Coastguard Worker }
2609*4bdc9457SAndroid Build Coastguard Worker }
2610*4bdc9457SAndroid Build Coastguard Worker }
2611*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,y_scale)2612*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, y_scale) {
2613*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2614*4bdc9457SAndroid Build Coastguard Worker for (float y_scale = 0.1f; y_scale <= 10.0f; y_scale *= 3.14f) {
2615*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2616*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2617*4bdc9457SAndroid Build Coastguard Worker .y_scale(y_scale)
2618*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2619*4bdc9457SAndroid Build Coastguard Worker }
2620*4bdc9457SAndroid Build Coastguard Worker }
2621*4bdc9457SAndroid Build Coastguard Worker }
2622*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,qmin)2623*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, qmin) {
2624*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2625*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2626*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2627*4bdc9457SAndroid Build Coastguard Worker .qmin(128)
2628*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2629*4bdc9457SAndroid Build Coastguard Worker }
2630*4bdc9457SAndroid Build Coastguard Worker }
2631*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4,qmax)2632*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VMUL_MINMAX_FP32__SCALAR_X4, qmax) {
2633*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2634*4bdc9457SAndroid Build Coastguard Worker VMulMicrokernelTester()
2635*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2636*4bdc9457SAndroid Build Coastguard Worker .qmax(128)
2637*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vmul_minmax_fp32_ukernel__scalar_x4, xnn_init_qu8_mul_minmax_fp32_scalar_params, xnn_qu8_requantize_fp32);
2638*4bdc9457SAndroid Build Coastguard Worker }
2639*4bdc9457SAndroid Build Coastguard Worker }