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