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/qu8-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(QU8_VCVT__NEON_X8,batch_eq_8)21*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_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<uint8_t>::min())
26*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
27*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
28*4bdc9457SAndroid Build Coastguard Worker }
29*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,batch_div_8)30*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_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<uint8_t>::min())
36*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
37*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
38*4bdc9457SAndroid Build Coastguard Worker }
39*4bdc9457SAndroid Build Coastguard Worker }
40*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,batch_lt_8)41*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_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<uint8_t>::min())
47*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
48*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
49*4bdc9457SAndroid Build Coastguard Worker }
50*4bdc9457SAndroid Build Coastguard Worker }
51*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,batch_gt_8)52*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_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<uint8_t>::min())
58*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
59*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
60*4bdc9457SAndroid Build Coastguard Worker }
61*4bdc9457SAndroid Build Coastguard Worker }
62*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,scale)63*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_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 .output_zero_point(100)
70*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
71*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
72*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
73*4bdc9457SAndroid Build Coastguard Worker }
74*4bdc9457SAndroid Build Coastguard Worker }
75*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,input_zero_point)76*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X8, input_zero_point) {
77*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
78*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
79*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
80*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
81*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
82*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
83*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
84*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
85*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
86*4bdc9457SAndroid Build Coastguard Worker }
87*4bdc9457SAndroid Build Coastguard Worker }
88*4bdc9457SAndroid Build Coastguard Worker }
89*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X8,output_zero_point)90*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X8, output_zero_point) {
91*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
92*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
93*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
94*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
95*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
96*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
97*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
98*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
99*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x8, xnn_init_qu8_cvt_neon_params);
100*4bdc9457SAndroid Build Coastguard Worker }
101*4bdc9457SAndroid Build Coastguard Worker }
102*4bdc9457SAndroid Build Coastguard Worker }
103*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
104*4bdc9457SAndroid Build Coastguard Worker
105*4bdc9457SAndroid Build Coastguard Worker
106*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(QU8_VCVT__NEON_X16,batch_eq_16)107*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, batch_eq_16) {
108*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
109*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
110*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
111*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
112*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
113*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
114*4bdc9457SAndroid Build Coastguard Worker }
115*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,batch_div_16)116*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, batch_div_16) {
117*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
118*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
119*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
120*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
121*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
122*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
123*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
124*4bdc9457SAndroid Build Coastguard Worker }
125*4bdc9457SAndroid Build Coastguard Worker }
126*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,batch_lt_16)127*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, batch_lt_16) {
128*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
129*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
130*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
131*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
132*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
133*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
134*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
135*4bdc9457SAndroid Build Coastguard Worker }
136*4bdc9457SAndroid Build Coastguard Worker }
137*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,batch_gt_16)138*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, batch_gt_16) {
139*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
140*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
141*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
142*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
143*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
144*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
145*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
146*4bdc9457SAndroid Build Coastguard Worker }
147*4bdc9457SAndroid Build Coastguard Worker }
148*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,scale)149*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, scale) {
150*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
151*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
152*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
153*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
154*4bdc9457SAndroid Build Coastguard Worker .scale(50)
155*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
156*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
157*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
158*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
159*4bdc9457SAndroid Build Coastguard Worker }
160*4bdc9457SAndroid Build Coastguard Worker }
161*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,input_zero_point)162*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, input_zero_point) {
163*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
164*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
165*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
166*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
167*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
168*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
169*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
170*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
171*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
172*4bdc9457SAndroid Build Coastguard Worker }
173*4bdc9457SAndroid Build Coastguard Worker }
174*4bdc9457SAndroid Build Coastguard Worker }
175*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X16,output_zero_point)176*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X16, output_zero_point) {
177*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
178*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
179*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
180*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
181*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
182*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
183*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
184*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
185*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x16, xnn_init_qu8_cvt_neon_params);
186*4bdc9457SAndroid Build Coastguard Worker }
187*4bdc9457SAndroid Build Coastguard Worker }
188*4bdc9457SAndroid Build Coastguard Worker }
189*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
190*4bdc9457SAndroid Build Coastguard Worker
191*4bdc9457SAndroid Build Coastguard Worker
192*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(QU8_VCVT__NEON_X32,batch_eq_32)193*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, batch_eq_32) {
194*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
195*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
196*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
197*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
198*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
199*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
200*4bdc9457SAndroid Build Coastguard Worker }
201*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,batch_div_32)202*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, batch_div_32) {
203*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
204*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
205*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
206*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
207*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
208*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
209*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
210*4bdc9457SAndroid Build Coastguard Worker }
211*4bdc9457SAndroid Build Coastguard Worker }
212*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,batch_lt_32)213*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, batch_lt_32) {
214*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
215*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
216*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
217*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
218*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
219*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
220*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
221*4bdc9457SAndroid Build Coastguard Worker }
222*4bdc9457SAndroid Build Coastguard Worker }
223*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,batch_gt_32)224*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, batch_gt_32) {
225*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
226*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
227*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
228*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
229*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
230*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
231*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
232*4bdc9457SAndroid Build Coastguard Worker }
233*4bdc9457SAndroid Build Coastguard Worker }
234*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,scale)235*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, scale) {
236*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
237*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
238*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
239*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
240*4bdc9457SAndroid Build Coastguard Worker .scale(50)
241*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
242*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
243*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
244*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
245*4bdc9457SAndroid Build Coastguard Worker }
246*4bdc9457SAndroid Build Coastguard Worker }
247*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,input_zero_point)248*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, input_zero_point) {
249*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
250*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
251*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
252*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
253*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
254*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
255*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
256*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
257*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
258*4bdc9457SAndroid Build Coastguard Worker }
259*4bdc9457SAndroid Build Coastguard Worker }
260*4bdc9457SAndroid Build Coastguard Worker }
261*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__NEON_X32,output_zero_point)262*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__NEON_X32, output_zero_point) {
263*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
264*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
265*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
266*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
267*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
268*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
269*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
270*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__neon_x32, xnn_init_qu8_cvt_neon_params);
272*4bdc9457SAndroid Build Coastguard Worker }
273*4bdc9457SAndroid Build Coastguard Worker }
274*4bdc9457SAndroid Build Coastguard Worker }
275*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
276*4bdc9457SAndroid Build Coastguard Worker
277*4bdc9457SAndroid Build Coastguard Worker
278*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSE2_X16,batch_eq_16)279*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, batch_eq_16) {
280*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
281*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
282*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
283*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
284*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
285*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
286*4bdc9457SAndroid Build Coastguard Worker }
287*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,batch_div_16)288*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, batch_div_16) {
289*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
290*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
291*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
292*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
293*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
294*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
295*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
296*4bdc9457SAndroid Build Coastguard Worker }
297*4bdc9457SAndroid Build Coastguard Worker }
298*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,batch_lt_16)299*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, batch_lt_16) {
300*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
301*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
302*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
303*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
304*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
305*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
306*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
307*4bdc9457SAndroid Build Coastguard Worker }
308*4bdc9457SAndroid Build Coastguard Worker }
309*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,batch_gt_16)310*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, batch_gt_16) {
311*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
312*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
313*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
314*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
315*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
316*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
317*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
318*4bdc9457SAndroid Build Coastguard Worker }
319*4bdc9457SAndroid Build Coastguard Worker }
320*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,scale)321*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, scale) {
322*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
323*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
324*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
325*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
326*4bdc9457SAndroid Build Coastguard Worker .scale(50)
327*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
328*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
329*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
330*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
331*4bdc9457SAndroid Build Coastguard Worker }
332*4bdc9457SAndroid Build Coastguard Worker }
333*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,input_zero_point)334*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, input_zero_point) {
335*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
336*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
337*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
338*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
339*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
340*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
341*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
342*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
343*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
344*4bdc9457SAndroid Build Coastguard Worker }
345*4bdc9457SAndroid Build Coastguard Worker }
346*4bdc9457SAndroid Build Coastguard Worker }
347*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X16,output_zero_point)348*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X16, output_zero_point) {
349*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
350*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
351*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
352*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
353*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
354*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
355*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
356*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
357*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x16, xnn_init_qu8_cvt_sse2_params);
358*4bdc9457SAndroid Build Coastguard Worker }
359*4bdc9457SAndroid Build Coastguard Worker }
360*4bdc9457SAndroid Build Coastguard Worker }
361*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
362*4bdc9457SAndroid Build Coastguard Worker
363*4bdc9457SAndroid Build Coastguard Worker
364*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSE2_X32,batch_eq_32)365*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, batch_eq_32) {
366*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
367*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
368*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
369*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
370*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
371*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
372*4bdc9457SAndroid Build Coastguard Worker }
373*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,batch_div_32)374*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, batch_div_32) {
375*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
376*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
377*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
378*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
379*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
380*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
381*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
382*4bdc9457SAndroid Build Coastguard Worker }
383*4bdc9457SAndroid Build Coastguard Worker }
384*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,batch_lt_32)385*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, batch_lt_32) {
386*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
387*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
388*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
389*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
390*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
391*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
392*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
393*4bdc9457SAndroid Build Coastguard Worker }
394*4bdc9457SAndroid Build Coastguard Worker }
395*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,batch_gt_32)396*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, batch_gt_32) {
397*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
398*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
399*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
400*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
401*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
402*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
404*4bdc9457SAndroid Build Coastguard Worker }
405*4bdc9457SAndroid Build Coastguard Worker }
406*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,scale)407*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, scale) {
408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
409*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
410*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
411*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
412*4bdc9457SAndroid Build Coastguard Worker .scale(50)
413*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
414*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
415*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
416*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
417*4bdc9457SAndroid Build Coastguard Worker }
418*4bdc9457SAndroid Build Coastguard Worker }
419*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,input_zero_point)420*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, input_zero_point) {
421*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
422*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
423*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
424*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
425*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
426*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
427*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
428*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
429*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
430*4bdc9457SAndroid Build Coastguard Worker }
431*4bdc9457SAndroid Build Coastguard Worker }
432*4bdc9457SAndroid Build Coastguard Worker }
433*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE2_X32,output_zero_point)434*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE2_X32, output_zero_point) {
435*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
436*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
437*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
438*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
439*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
440*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
441*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
442*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
443*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse2_x32, xnn_init_qu8_cvt_sse2_params);
444*4bdc9457SAndroid Build Coastguard Worker }
445*4bdc9457SAndroid Build Coastguard Worker }
446*4bdc9457SAndroid Build Coastguard Worker }
447*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
448*4bdc9457SAndroid Build Coastguard Worker
449*4bdc9457SAndroid Build Coastguard Worker
450*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSSE3_X16,batch_eq_16)451*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, batch_eq_16) {
452*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
453*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
454*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
455*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
456*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
457*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
458*4bdc9457SAndroid Build Coastguard Worker }
459*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,batch_div_16)460*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, batch_div_16) {
461*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
462*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
463*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
464*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
465*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
466*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
467*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
468*4bdc9457SAndroid Build Coastguard Worker }
469*4bdc9457SAndroid Build Coastguard Worker }
470*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,batch_lt_16)471*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, batch_lt_16) {
472*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
473*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
474*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
475*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
476*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
477*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
478*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
479*4bdc9457SAndroid Build Coastguard Worker }
480*4bdc9457SAndroid Build Coastguard Worker }
481*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,batch_gt_16)482*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, batch_gt_16) {
483*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
484*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
485*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
486*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
487*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
488*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
489*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
490*4bdc9457SAndroid Build Coastguard Worker }
491*4bdc9457SAndroid Build Coastguard Worker }
492*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,scale)493*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, scale) {
494*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
495*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
496*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
497*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
498*4bdc9457SAndroid Build Coastguard Worker .scale(50)
499*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
500*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
501*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
503*4bdc9457SAndroid Build Coastguard Worker }
504*4bdc9457SAndroid Build Coastguard Worker }
505*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,input_zero_point)506*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, input_zero_point) {
507*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
508*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
509*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
510*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
511*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
512*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
513*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
514*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
515*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
516*4bdc9457SAndroid Build Coastguard Worker }
517*4bdc9457SAndroid Build Coastguard Worker }
518*4bdc9457SAndroid Build Coastguard Worker }
519*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X16,output_zero_point)520*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X16, output_zero_point) {
521*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
522*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
523*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
524*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
525*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
526*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
527*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
528*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
529*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x16, xnn_init_qu8_cvt_ssse3_params);
530*4bdc9457SAndroid Build Coastguard Worker }
531*4bdc9457SAndroid Build Coastguard Worker }
532*4bdc9457SAndroid Build Coastguard Worker }
533*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
534*4bdc9457SAndroid Build Coastguard Worker
535*4bdc9457SAndroid Build Coastguard Worker
536*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSSE3_X32,batch_eq_32)537*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, batch_eq_32) {
538*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
539*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
540*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
541*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
542*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
543*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
544*4bdc9457SAndroid Build Coastguard Worker }
545*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,batch_div_32)546*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, batch_div_32) {
547*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
548*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
549*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
550*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
551*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
552*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
553*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
554*4bdc9457SAndroid Build Coastguard Worker }
555*4bdc9457SAndroid Build Coastguard Worker }
556*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,batch_lt_32)557*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, batch_lt_32) {
558*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
559*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
560*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
561*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
562*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
563*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
564*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
565*4bdc9457SAndroid Build Coastguard Worker }
566*4bdc9457SAndroid Build Coastguard Worker }
567*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,batch_gt_32)568*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, batch_gt_32) {
569*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
570*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
571*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
572*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
573*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
574*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
575*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
576*4bdc9457SAndroid Build Coastguard Worker }
577*4bdc9457SAndroid Build Coastguard Worker }
578*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,scale)579*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, scale) {
580*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
581*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
582*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
583*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
584*4bdc9457SAndroid Build Coastguard Worker .scale(50)
585*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
586*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
587*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
588*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
589*4bdc9457SAndroid Build Coastguard Worker }
590*4bdc9457SAndroid Build Coastguard Worker }
591*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,input_zero_point)592*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, input_zero_point) {
593*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
594*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
595*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
596*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
597*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
598*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
599*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
600*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
601*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
602*4bdc9457SAndroid Build Coastguard Worker }
603*4bdc9457SAndroid Build Coastguard Worker }
604*4bdc9457SAndroid Build Coastguard Worker }
605*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSSE3_X32,output_zero_point)606*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSSE3_X32, output_zero_point) {
607*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSSE3;
608*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
609*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
610*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
611*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
612*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
613*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
614*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
615*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__ssse3_x32, xnn_init_qu8_cvt_ssse3_params);
616*4bdc9457SAndroid Build Coastguard Worker }
617*4bdc9457SAndroid Build Coastguard Worker }
618*4bdc9457SAndroid Build Coastguard Worker }
619*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
620*4bdc9457SAndroid Build Coastguard Worker
621*4bdc9457SAndroid Build Coastguard Worker
622*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX_X8,batch_eq_8)623*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, batch_eq_8) {
624*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
625*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
626*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
627*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
628*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
629*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
630*4bdc9457SAndroid Build Coastguard Worker }
631*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,batch_div_8)632*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, batch_div_8) {
633*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
634*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
635*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
636*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
637*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
638*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
639*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
640*4bdc9457SAndroid Build Coastguard Worker }
641*4bdc9457SAndroid Build Coastguard Worker }
642*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,batch_lt_8)643*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, batch_lt_8) {
644*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
645*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
646*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
647*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
648*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
649*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
650*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
651*4bdc9457SAndroid Build Coastguard Worker }
652*4bdc9457SAndroid Build Coastguard Worker }
653*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,batch_gt_8)654*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, batch_gt_8) {
655*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
656*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
657*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
658*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
659*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
660*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
661*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
662*4bdc9457SAndroid Build Coastguard Worker }
663*4bdc9457SAndroid Build Coastguard Worker }
664*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,scale)665*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, scale) {
666*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
667*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
668*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
669*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
670*4bdc9457SAndroid Build Coastguard Worker .scale(50)
671*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
672*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
673*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
674*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
675*4bdc9457SAndroid Build Coastguard Worker }
676*4bdc9457SAndroid Build Coastguard Worker }
677*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,input_zero_point)678*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, input_zero_point) {
679*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
680*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
681*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
682*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
683*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
684*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
685*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
686*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
687*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
688*4bdc9457SAndroid Build Coastguard Worker }
689*4bdc9457SAndroid Build Coastguard Worker }
690*4bdc9457SAndroid Build Coastguard Worker }
691*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X8,output_zero_point)692*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X8, output_zero_point) {
693*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
694*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
695*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
696*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
697*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
698*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
699*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
700*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
701*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x8, xnn_init_qu8_cvt_ssse3_params);
702*4bdc9457SAndroid Build Coastguard Worker }
703*4bdc9457SAndroid Build Coastguard Worker }
704*4bdc9457SAndroid Build Coastguard Worker }
705*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
706*4bdc9457SAndroid Build Coastguard Worker
707*4bdc9457SAndroid Build Coastguard Worker
708*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX_X16,batch_eq_16)709*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, batch_eq_16) {
710*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
711*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
712*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
713*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
714*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
715*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
716*4bdc9457SAndroid Build Coastguard Worker }
717*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,batch_div_16)718*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, batch_div_16) {
719*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
720*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
721*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
722*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
723*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
724*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
725*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
726*4bdc9457SAndroid Build Coastguard Worker }
727*4bdc9457SAndroid Build Coastguard Worker }
728*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,batch_lt_16)729*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, batch_lt_16) {
730*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
731*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
732*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
733*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
734*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
735*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
736*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
737*4bdc9457SAndroid Build Coastguard Worker }
738*4bdc9457SAndroid Build Coastguard Worker }
739*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,batch_gt_16)740*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, batch_gt_16) {
741*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
742*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
743*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
744*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
745*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
746*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
747*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
748*4bdc9457SAndroid Build Coastguard Worker }
749*4bdc9457SAndroid Build Coastguard Worker }
750*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,scale)751*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, scale) {
752*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
753*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
754*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
755*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
756*4bdc9457SAndroid Build Coastguard Worker .scale(50)
757*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
758*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
759*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
760*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
761*4bdc9457SAndroid Build Coastguard Worker }
762*4bdc9457SAndroid Build Coastguard Worker }
763*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,input_zero_point)764*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, input_zero_point) {
765*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
766*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
767*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
768*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
769*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
770*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
771*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
772*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
773*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
774*4bdc9457SAndroid Build Coastguard Worker }
775*4bdc9457SAndroid Build Coastguard Worker }
776*4bdc9457SAndroid Build Coastguard Worker }
777*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X16,output_zero_point)778*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X16, output_zero_point) {
779*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
780*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
781*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
782*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
783*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
784*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
785*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
786*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
787*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x16, xnn_init_qu8_cvt_ssse3_params);
788*4bdc9457SAndroid Build Coastguard Worker }
789*4bdc9457SAndroid Build Coastguard Worker }
790*4bdc9457SAndroid Build Coastguard Worker }
791*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
792*4bdc9457SAndroid Build Coastguard Worker
793*4bdc9457SAndroid Build Coastguard Worker
794*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX_X32,batch_eq_32)795*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, batch_eq_32) {
796*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
797*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
798*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
799*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
800*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
801*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
802*4bdc9457SAndroid Build Coastguard Worker }
803*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,batch_div_32)804*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, batch_div_32) {
805*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
806*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
807*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
808*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
809*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
810*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
811*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
812*4bdc9457SAndroid Build Coastguard Worker }
813*4bdc9457SAndroid Build Coastguard Worker }
814*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,batch_lt_32)815*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, batch_lt_32) {
816*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
817*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
818*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
819*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
820*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
821*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
822*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
823*4bdc9457SAndroid Build Coastguard Worker }
824*4bdc9457SAndroid Build Coastguard Worker }
825*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,batch_gt_32)826*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, batch_gt_32) {
827*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
828*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
829*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
830*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
831*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
832*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
833*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
834*4bdc9457SAndroid Build Coastguard Worker }
835*4bdc9457SAndroid Build Coastguard Worker }
836*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,scale)837*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, scale) {
838*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
839*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
840*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
841*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
842*4bdc9457SAndroid Build Coastguard Worker .scale(50)
843*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
844*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
845*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
846*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
847*4bdc9457SAndroid Build Coastguard Worker }
848*4bdc9457SAndroid Build Coastguard Worker }
849*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,input_zero_point)850*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, input_zero_point) {
851*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
852*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
853*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
854*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
855*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
856*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
857*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
858*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
859*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
860*4bdc9457SAndroid Build Coastguard Worker }
861*4bdc9457SAndroid Build Coastguard Worker }
862*4bdc9457SAndroid Build Coastguard Worker }
863*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX_X32,output_zero_point)864*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX_X32, output_zero_point) {
865*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX;
866*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
867*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
868*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
869*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
870*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
871*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
872*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
873*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx_x32, xnn_init_qu8_cvt_ssse3_params);
874*4bdc9457SAndroid Build Coastguard Worker }
875*4bdc9457SAndroid Build Coastguard Worker }
876*4bdc9457SAndroid Build Coastguard Worker }
877*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
878*4bdc9457SAndroid Build Coastguard Worker
879*4bdc9457SAndroid Build Coastguard Worker
880*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSE41_X8,batch_eq_8)881*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, batch_eq_8) {
882*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
883*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
884*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
885*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
886*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
888*4bdc9457SAndroid Build Coastguard Worker }
889*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,batch_div_8)890*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, batch_div_8) {
891*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
892*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
893*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
894*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
895*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
896*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
897*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
898*4bdc9457SAndroid Build Coastguard Worker }
899*4bdc9457SAndroid Build Coastguard Worker }
900*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,batch_lt_8)901*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, batch_lt_8) {
902*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
903*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
904*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
905*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
906*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
907*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
908*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
909*4bdc9457SAndroid Build Coastguard Worker }
910*4bdc9457SAndroid Build Coastguard Worker }
911*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,batch_gt_8)912*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, batch_gt_8) {
913*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
914*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
915*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
916*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
917*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
918*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
919*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
920*4bdc9457SAndroid Build Coastguard Worker }
921*4bdc9457SAndroid Build Coastguard Worker }
922*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,scale)923*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, scale) {
924*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
925*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
926*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
927*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
928*4bdc9457SAndroid Build Coastguard Worker .scale(50)
929*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
930*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
931*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
932*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
933*4bdc9457SAndroid Build Coastguard Worker }
934*4bdc9457SAndroid Build Coastguard Worker }
935*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,input_zero_point)936*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, input_zero_point) {
937*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
938*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
939*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
940*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
941*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
942*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
943*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
944*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
945*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
946*4bdc9457SAndroid Build Coastguard Worker }
947*4bdc9457SAndroid Build Coastguard Worker }
948*4bdc9457SAndroid Build Coastguard Worker }
949*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X8,output_zero_point)950*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X8, output_zero_point) {
951*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
952*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
953*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
954*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
955*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
956*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
957*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
958*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
959*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x8, xnn_init_qu8_cvt_ssse3_params);
960*4bdc9457SAndroid Build Coastguard Worker }
961*4bdc9457SAndroid Build Coastguard Worker }
962*4bdc9457SAndroid Build Coastguard Worker }
963*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
964*4bdc9457SAndroid Build Coastguard Worker
965*4bdc9457SAndroid Build Coastguard Worker
966*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSE41_X16,batch_eq_16)967*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, batch_eq_16) {
968*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
969*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
970*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
971*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
972*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
973*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
974*4bdc9457SAndroid Build Coastguard Worker }
975*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,batch_div_16)976*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, batch_div_16) {
977*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
978*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
979*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
980*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
981*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
982*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
983*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
984*4bdc9457SAndroid Build Coastguard Worker }
985*4bdc9457SAndroid Build Coastguard Worker }
986*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,batch_lt_16)987*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, batch_lt_16) {
988*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
989*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
990*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
991*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
992*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
993*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
994*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
995*4bdc9457SAndroid Build Coastguard Worker }
996*4bdc9457SAndroid Build Coastguard Worker }
997*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,batch_gt_16)998*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, batch_gt_16) {
999*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1000*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1001*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1002*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1003*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1004*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1005*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
1006*4bdc9457SAndroid Build Coastguard Worker }
1007*4bdc9457SAndroid Build Coastguard Worker }
1008*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,scale)1009*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, scale) {
1010*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1011*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1012*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1013*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1014*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1015*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1016*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1017*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1018*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
1019*4bdc9457SAndroid Build Coastguard Worker }
1020*4bdc9457SAndroid Build Coastguard Worker }
1021*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,input_zero_point)1022*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, input_zero_point) {
1023*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1024*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1025*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1026*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1027*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1028*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1029*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1030*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1031*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
1032*4bdc9457SAndroid Build Coastguard Worker }
1033*4bdc9457SAndroid Build Coastguard Worker }
1034*4bdc9457SAndroid Build Coastguard Worker }
1035*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X16,output_zero_point)1036*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X16, output_zero_point) {
1037*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1038*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1039*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1040*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1041*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1042*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1043*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1044*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1045*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x16, xnn_init_qu8_cvt_ssse3_params);
1046*4bdc9457SAndroid Build Coastguard Worker }
1047*4bdc9457SAndroid Build Coastguard Worker }
1048*4bdc9457SAndroid Build Coastguard Worker }
1049*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1050*4bdc9457SAndroid Build Coastguard Worker
1051*4bdc9457SAndroid Build Coastguard Worker
1052*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__SSE41_X32,batch_eq_32)1053*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, batch_eq_32) {
1054*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1055*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1056*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
1057*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1058*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1059*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1060*4bdc9457SAndroid Build Coastguard Worker }
1061*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,batch_div_32)1062*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, batch_div_32) {
1063*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1064*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
1065*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1066*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1067*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1068*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1069*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1070*4bdc9457SAndroid Build Coastguard Worker }
1071*4bdc9457SAndroid Build Coastguard Worker }
1072*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,batch_lt_32)1073*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, batch_lt_32) {
1074*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1075*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
1076*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1077*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1078*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1079*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1081*4bdc9457SAndroid Build Coastguard Worker }
1082*4bdc9457SAndroid Build Coastguard Worker }
1083*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,batch_gt_32)1084*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, batch_gt_32) {
1085*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1086*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
1087*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1088*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1089*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1090*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1091*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1092*4bdc9457SAndroid Build Coastguard Worker }
1093*4bdc9457SAndroid Build Coastguard Worker }
1094*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,scale)1095*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, scale) {
1096*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1097*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1098*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1099*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1100*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1101*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1102*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1103*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1105*4bdc9457SAndroid Build Coastguard Worker }
1106*4bdc9457SAndroid Build Coastguard Worker }
1107*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,input_zero_point)1108*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, input_zero_point) {
1109*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1110*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1111*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1112*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1113*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1114*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1115*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1116*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1117*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1118*4bdc9457SAndroid Build Coastguard Worker }
1119*4bdc9457SAndroid Build Coastguard Worker }
1120*4bdc9457SAndroid Build Coastguard Worker }
1121*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SSE41_X32,output_zero_point)1122*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SSE41_X32, output_zero_point) {
1123*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE41;
1124*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1125*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1126*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1127*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1128*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1129*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1130*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1131*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__sse41_x32, xnn_init_qu8_cvt_ssse3_params);
1132*4bdc9457SAndroid Build Coastguard Worker }
1133*4bdc9457SAndroid Build Coastguard Worker }
1134*4bdc9457SAndroid Build Coastguard Worker }
1135*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1136*4bdc9457SAndroid Build Coastguard Worker
1137*4bdc9457SAndroid Build Coastguard Worker
1138*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX2_X16,batch_eq_16)1139*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, batch_eq_16) {
1140*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1141*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1142*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1143*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1144*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1145*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1146*4bdc9457SAndroid Build Coastguard Worker }
1147*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,batch_div_16)1148*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, batch_div_16) {
1149*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1150*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
1151*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1152*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1153*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1154*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1155*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1156*4bdc9457SAndroid Build Coastguard Worker }
1157*4bdc9457SAndroid Build Coastguard Worker }
1158*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,batch_lt_16)1159*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, batch_lt_16) {
1160*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1161*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; 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<uint8_t>::min())
1165*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1166*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1167*4bdc9457SAndroid Build Coastguard Worker }
1168*4bdc9457SAndroid Build Coastguard Worker }
1169*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,batch_gt_16)1170*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, batch_gt_16) {
1171*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1172*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1173*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1174*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1175*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1176*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1177*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1178*4bdc9457SAndroid Build Coastguard Worker }
1179*4bdc9457SAndroid Build Coastguard Worker }
1180*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,scale)1181*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, scale) {
1182*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1183*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1184*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1185*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1186*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1187*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1188*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1189*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1190*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1191*4bdc9457SAndroid Build Coastguard Worker }
1192*4bdc9457SAndroid Build Coastguard Worker }
1193*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,input_zero_point)1194*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, input_zero_point) {
1195*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1196*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1197*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1198*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1199*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1200*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1201*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1202*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1203*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1204*4bdc9457SAndroid Build Coastguard Worker }
1205*4bdc9457SAndroid Build Coastguard Worker }
1206*4bdc9457SAndroid Build Coastguard Worker }
1207*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X16,output_zero_point)1208*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X16, output_zero_point) {
1209*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1210*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1211*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1212*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1213*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1214*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1215*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1216*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1217*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x16, xnn_init_qu8_cvt_avx2_params);
1218*4bdc9457SAndroid Build Coastguard Worker }
1219*4bdc9457SAndroid Build Coastguard Worker }
1220*4bdc9457SAndroid Build Coastguard Worker }
1221*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1222*4bdc9457SAndroid Build Coastguard Worker
1223*4bdc9457SAndroid Build Coastguard Worker
1224*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX2_X32,batch_eq_32)1225*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, batch_eq_32) {
1226*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1227*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1228*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
1229*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1230*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1231*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1232*4bdc9457SAndroid Build Coastguard Worker }
1233*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,batch_div_32)1234*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, batch_div_32) {
1235*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1236*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
1237*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1238*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1239*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1240*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1241*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1242*4bdc9457SAndroid Build Coastguard Worker }
1243*4bdc9457SAndroid Build Coastguard Worker }
1244*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,batch_lt_32)1245*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, batch_lt_32) {
1246*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1247*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
1248*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1249*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1250*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1251*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1252*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1253*4bdc9457SAndroid Build Coastguard Worker }
1254*4bdc9457SAndroid Build Coastguard Worker }
1255*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,batch_gt_32)1256*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, batch_gt_32) {
1257*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1258*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
1259*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1260*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1261*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1262*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1263*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1264*4bdc9457SAndroid Build Coastguard Worker }
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,scale)1267*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, scale) {
1268*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1269*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1270*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1271*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1272*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1273*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1274*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1275*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1276*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1277*4bdc9457SAndroid Build Coastguard Worker }
1278*4bdc9457SAndroid Build Coastguard Worker }
1279*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,input_zero_point)1280*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, input_zero_point) {
1281*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1282*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1283*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1284*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1285*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1286*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1287*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1288*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1289*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1290*4bdc9457SAndroid Build Coastguard Worker }
1291*4bdc9457SAndroid Build Coastguard Worker }
1292*4bdc9457SAndroid Build Coastguard Worker }
1293*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X32,output_zero_point)1294*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X32, output_zero_point) {
1295*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1296*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1297*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1298*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1299*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1300*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1301*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1302*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1303*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x32, xnn_init_qu8_cvt_avx2_params);
1304*4bdc9457SAndroid Build Coastguard Worker }
1305*4bdc9457SAndroid Build Coastguard Worker }
1306*4bdc9457SAndroid Build Coastguard Worker }
1307*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1308*4bdc9457SAndroid Build Coastguard Worker
1309*4bdc9457SAndroid Build Coastguard Worker
1310*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(QU8_VCVT__AVX2_X64,batch_eq_64)1311*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, batch_eq_64) {
1312*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1313*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1314*4bdc9457SAndroid Build Coastguard Worker .batch_size(64)
1315*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1316*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1317*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1318*4bdc9457SAndroid Build Coastguard Worker }
1319*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,batch_div_64)1320*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, batch_div_64) {
1321*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1322*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 128; batch_size < 640; batch_size += 64) {
1323*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1324*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1325*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1326*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1327*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1328*4bdc9457SAndroid Build Coastguard Worker }
1329*4bdc9457SAndroid Build Coastguard Worker }
1330*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,batch_lt_64)1331*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, batch_lt_64) {
1332*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1333*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 64; batch_size++) {
1334*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1335*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1336*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1337*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1338*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1339*4bdc9457SAndroid Build Coastguard Worker }
1340*4bdc9457SAndroid Build Coastguard Worker }
1341*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,batch_gt_64)1342*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, batch_gt_64) {
1343*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1344*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 65; batch_size < 128; batch_size++) {
1345*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1346*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1347*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1348*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1349*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1350*4bdc9457SAndroid Build Coastguard Worker }
1351*4bdc9457SAndroid Build Coastguard Worker }
1352*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,scale)1353*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, scale) {
1354*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1355*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 320; batch_size += 63) {
1356*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1357*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1358*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1359*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1360*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1361*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1362*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1363*4bdc9457SAndroid Build Coastguard Worker }
1364*4bdc9457SAndroid Build Coastguard Worker }
1365*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,input_zero_point)1366*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, input_zero_point) {
1367*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1368*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1369*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 320; batch_size += 63) {
1370*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1371*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1372*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1373*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1374*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1375*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker }
1378*4bdc9457SAndroid Build Coastguard Worker }
1379*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__AVX2_X64,output_zero_point)1380*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__AVX2_X64, output_zero_point) {
1381*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
1382*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1383*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 320; batch_size += 63) {
1384*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1385*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1386*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1387*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1388*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1389*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__avx2_x64, xnn_init_qu8_cvt_avx2_params);
1390*4bdc9457SAndroid Build Coastguard Worker }
1391*4bdc9457SAndroid Build Coastguard Worker }
1392*4bdc9457SAndroid Build Coastguard Worker }
1393*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1394*4bdc9457SAndroid Build Coastguard Worker
1395*4bdc9457SAndroid Build Coastguard Worker
1396*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMSIMD_X8,batch_eq_8)1397*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, batch_eq_8) {
1398*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1399*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1400*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1401*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1402*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1403*4bdc9457SAndroid Build Coastguard Worker }
1404*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,batch_div_8)1405*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, batch_div_8) {
1406*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1407*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1408*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1409*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1410*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,batch_lt_8)1415*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, batch_lt_8) {
1416*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
1417*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1418*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1419*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1420*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1421*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1422*4bdc9457SAndroid Build Coastguard Worker }
1423*4bdc9457SAndroid Build Coastguard Worker }
1424*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,batch_gt_8)1425*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, batch_gt_8) {
1426*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1427*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1428*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1429*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1430*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1431*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1432*4bdc9457SAndroid Build Coastguard Worker }
1433*4bdc9457SAndroid Build Coastguard Worker }
1434*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,scale)1435*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, scale) {
1436*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1437*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1438*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1439*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1440*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1441*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1442*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1443*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1444*4bdc9457SAndroid Build Coastguard Worker }
1445*4bdc9457SAndroid Build Coastguard Worker }
1446*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,input_zero_point)1447*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, input_zero_point) {
1448*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1449*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1450*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1451*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1452*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1453*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1454*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1455*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1456*4bdc9457SAndroid Build Coastguard Worker }
1457*4bdc9457SAndroid Build Coastguard Worker }
1458*4bdc9457SAndroid Build Coastguard Worker }
1459*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X8,output_zero_point)1460*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X8, output_zero_point) {
1461*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1462*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1463*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1464*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1465*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1466*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1467*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1468*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1469*4bdc9457SAndroid Build Coastguard Worker }
1470*4bdc9457SAndroid Build Coastguard Worker }
1471*4bdc9457SAndroid Build Coastguard Worker }
1472*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
1473*4bdc9457SAndroid Build Coastguard Worker
1474*4bdc9457SAndroid Build Coastguard Worker
1475*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMSIMD_X16,batch_eq_16)1476*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, batch_eq_16) {
1477*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1478*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1479*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1480*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1481*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1482*4bdc9457SAndroid Build Coastguard Worker }
1483*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,batch_div_16)1484*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, batch_div_16) {
1485*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
1486*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1487*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1488*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1489*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1490*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1491*4bdc9457SAndroid Build Coastguard Worker }
1492*4bdc9457SAndroid Build Coastguard Worker }
1493*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,batch_lt_16)1494*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, batch_lt_16) {
1495*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
1496*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1497*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1498*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1499*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1500*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1501*4bdc9457SAndroid Build Coastguard Worker }
1502*4bdc9457SAndroid Build Coastguard Worker }
1503*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,batch_gt_16)1504*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, batch_gt_16) {
1505*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1506*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1507*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1508*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1509*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1511*4bdc9457SAndroid Build Coastguard Worker }
1512*4bdc9457SAndroid Build Coastguard Worker }
1513*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,scale)1514*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, scale) {
1515*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1516*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1517*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1518*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1519*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1520*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1521*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1522*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1523*4bdc9457SAndroid Build Coastguard Worker }
1524*4bdc9457SAndroid Build Coastguard Worker }
1525*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,input_zero_point)1526*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, input_zero_point) {
1527*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1528*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1529*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1530*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1531*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1532*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1533*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1534*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1535*4bdc9457SAndroid Build Coastguard Worker }
1536*4bdc9457SAndroid Build Coastguard Worker }
1537*4bdc9457SAndroid Build Coastguard Worker }
1538*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X16,output_zero_point)1539*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X16, output_zero_point) {
1540*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1541*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1542*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1543*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1544*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1545*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1546*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1547*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1548*4bdc9457SAndroid Build Coastguard Worker }
1549*4bdc9457SAndroid Build Coastguard Worker }
1550*4bdc9457SAndroid Build Coastguard Worker }
1551*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
1552*4bdc9457SAndroid Build Coastguard Worker
1553*4bdc9457SAndroid Build Coastguard Worker
1554*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMSIMD_X32,batch_eq_32)1555*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, batch_eq_32) {
1556*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1557*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
1558*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1559*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1560*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1561*4bdc9457SAndroid Build Coastguard Worker }
1562*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,batch_div_32)1563*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, batch_div_32) {
1564*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
1565*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1566*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1567*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1568*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1569*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1570*4bdc9457SAndroid Build Coastguard Worker }
1571*4bdc9457SAndroid Build Coastguard Worker }
1572*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,batch_lt_32)1573*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, batch_lt_32) {
1574*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
1575*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1576*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1577*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1578*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1579*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1580*4bdc9457SAndroid Build Coastguard Worker }
1581*4bdc9457SAndroid Build Coastguard Worker }
1582*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,batch_gt_32)1583*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, batch_gt_32) {
1584*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
1585*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1586*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1587*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1588*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1589*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1590*4bdc9457SAndroid Build Coastguard Worker }
1591*4bdc9457SAndroid Build Coastguard Worker }
1592*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,scale)1593*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, scale) {
1594*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1595*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1596*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1597*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1598*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1599*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1600*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1601*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1602*4bdc9457SAndroid Build Coastguard Worker }
1603*4bdc9457SAndroid Build Coastguard Worker }
1604*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,input_zero_point)1605*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, input_zero_point) {
1606*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1607*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1608*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1609*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1610*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1611*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1612*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1613*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1614*4bdc9457SAndroid Build Coastguard Worker }
1615*4bdc9457SAndroid Build Coastguard Worker }
1616*4bdc9457SAndroid Build Coastguard Worker }
1617*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMSIMD_X32,output_zero_point)1618*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMSIMD_X32, output_zero_point) {
1619*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1620*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1621*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1622*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1623*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1624*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1625*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1626*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1627*4bdc9457SAndroid Build Coastguard Worker }
1628*4bdc9457SAndroid Build Coastguard Worker }
1629*4bdc9457SAndroid Build Coastguard Worker }
1630*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
1631*4bdc9457SAndroid Build Coastguard Worker
1632*4bdc9457SAndroid Build Coastguard Worker
1633*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,batch_eq_8)1634*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, batch_eq_8) {
1635*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1636*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1637*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1638*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1639*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1640*4bdc9457SAndroid Build Coastguard Worker }
1641*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,batch_div_8)1642*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, batch_div_8) {
1643*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1644*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1645*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1646*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1647*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1648*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1649*4bdc9457SAndroid Build Coastguard Worker }
1650*4bdc9457SAndroid Build Coastguard Worker }
1651*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,batch_lt_8)1652*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, batch_lt_8) {
1653*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; 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<uint8_t>::min())
1657*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1658*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1659*4bdc9457SAndroid Build Coastguard Worker }
1660*4bdc9457SAndroid Build Coastguard Worker }
1661*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,batch_gt_8)1662*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, batch_gt_8) {
1663*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1664*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1665*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1666*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1667*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1668*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1669*4bdc9457SAndroid Build Coastguard Worker }
1670*4bdc9457SAndroid Build Coastguard Worker }
1671*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,scale)1672*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, scale) {
1673*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1674*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1675*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1676*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1677*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1678*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1679*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1680*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1681*4bdc9457SAndroid Build Coastguard Worker }
1682*4bdc9457SAndroid Build Coastguard Worker }
1683*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,input_zero_point)1684*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, input_zero_point) {
1685*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1686*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1687*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1688*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1689*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1690*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1691*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1692*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1693*4bdc9457SAndroid Build Coastguard Worker }
1694*4bdc9457SAndroid Build Coastguard Worker }
1695*4bdc9457SAndroid Build Coastguard Worker }
1696*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X8,output_zero_point)1697*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X8, output_zero_point) {
1698*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1699*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
1700*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1701*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1702*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1703*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1704*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1705*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x8, xnn_init_qu8_cvt_wasmsimd_params);
1706*4bdc9457SAndroid Build Coastguard Worker }
1707*4bdc9457SAndroid Build Coastguard Worker }
1708*4bdc9457SAndroid Build Coastguard Worker }
1709*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMRELAXEDSIMD
1710*4bdc9457SAndroid Build Coastguard Worker
1711*4bdc9457SAndroid Build Coastguard Worker
1712*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,batch_eq_16)1713*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, batch_eq_16) {
1714*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1715*4bdc9457SAndroid Build Coastguard Worker .batch_size(16)
1716*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1717*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1718*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1719*4bdc9457SAndroid Build Coastguard Worker }
1720*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,batch_div_16)1721*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, batch_div_16) {
1722*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 32; batch_size < 160; batch_size += 16) {
1723*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1724*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1725*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1726*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1728*4bdc9457SAndroid Build Coastguard Worker }
1729*4bdc9457SAndroid Build Coastguard Worker }
1730*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,batch_lt_16)1731*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, batch_lt_16) {
1732*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 16; batch_size++) {
1733*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1734*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1735*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1736*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1737*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1738*4bdc9457SAndroid Build Coastguard Worker }
1739*4bdc9457SAndroid Build Coastguard Worker }
1740*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,batch_gt_16)1741*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, batch_gt_16) {
1742*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 17; batch_size < 32; batch_size++) {
1743*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1744*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1745*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1746*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1747*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1748*4bdc9457SAndroid Build Coastguard Worker }
1749*4bdc9457SAndroid Build Coastguard Worker }
1750*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,scale)1751*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, scale) {
1752*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1753*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1754*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1755*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1756*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1757*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1758*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1759*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1760*4bdc9457SAndroid Build Coastguard Worker }
1761*4bdc9457SAndroid Build Coastguard Worker }
1762*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,input_zero_point)1763*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, input_zero_point) {
1764*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1765*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1766*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1767*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1768*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1769*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1770*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1771*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1772*4bdc9457SAndroid Build Coastguard Worker }
1773*4bdc9457SAndroid Build Coastguard Worker }
1774*4bdc9457SAndroid Build Coastguard Worker }
1775*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X16,output_zero_point)1776*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X16, output_zero_point) {
1777*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1778*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 80; batch_size += 15) {
1779*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1780*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1781*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1782*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1783*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1784*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x16, xnn_init_qu8_cvt_wasmsimd_params);
1785*4bdc9457SAndroid Build Coastguard Worker }
1786*4bdc9457SAndroid Build Coastguard Worker }
1787*4bdc9457SAndroid Build Coastguard Worker }
1788*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMRELAXEDSIMD
1789*4bdc9457SAndroid Build Coastguard Worker
1790*4bdc9457SAndroid Build Coastguard Worker
1791*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMRELAXEDSIMD
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,batch_eq_32)1792*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, batch_eq_32) {
1793*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1794*4bdc9457SAndroid Build Coastguard Worker .batch_size(32)
1795*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1796*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1797*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1798*4bdc9457SAndroid Build Coastguard Worker }
1799*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,batch_div_32)1800*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, batch_div_32) {
1801*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 64; batch_size < 320; batch_size += 32) {
1802*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1803*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1804*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1805*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1806*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1807*4bdc9457SAndroid Build Coastguard Worker }
1808*4bdc9457SAndroid Build Coastguard Worker }
1809*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,batch_lt_32)1810*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, batch_lt_32) {
1811*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 32; batch_size++) {
1812*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1813*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1814*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1815*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1816*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1817*4bdc9457SAndroid Build Coastguard Worker }
1818*4bdc9457SAndroid Build Coastguard Worker }
1819*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,batch_gt_32)1820*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, batch_gt_32) {
1821*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 33; batch_size < 64; batch_size++) {
1822*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1823*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1824*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1825*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1826*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1827*4bdc9457SAndroid Build Coastguard Worker }
1828*4bdc9457SAndroid Build Coastguard Worker }
1829*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,scale)1830*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, scale) {
1831*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1832*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1833*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1834*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1835*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1836*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1837*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1838*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1839*4bdc9457SAndroid Build Coastguard Worker }
1840*4bdc9457SAndroid Build Coastguard Worker }
1841*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,input_zero_point)1842*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, input_zero_point) {
1843*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1844*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1845*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1846*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1847*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1848*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1849*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1850*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1851*4bdc9457SAndroid Build Coastguard Worker }
1852*4bdc9457SAndroid Build Coastguard Worker }
1853*4bdc9457SAndroid Build Coastguard Worker }
1854*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__WASMRELAXEDSIMD_X32,output_zero_point)1855*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__WASMRELAXEDSIMD_X32, output_zero_point) {
1856*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1857*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 160; batch_size += 31) {
1858*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1859*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1860*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1861*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1862*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1863*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__wasmrelaxedsimd_x32, xnn_init_qu8_cvt_wasmsimd_params);
1864*4bdc9457SAndroid Build Coastguard Worker }
1865*4bdc9457SAndroid Build Coastguard Worker }
1866*4bdc9457SAndroid Build Coastguard Worker }
1867*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMRELAXEDSIMD
1868*4bdc9457SAndroid Build Coastguard Worker
1869*4bdc9457SAndroid Build Coastguard Worker
1870*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM
TEST(QU8_VCVT__ARMSIMD32_X4,batch_eq_4)1871*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, batch_eq_4) {
1872*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1873*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1874*4bdc9457SAndroid Build Coastguard Worker .batch_size(4)
1875*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1876*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1877*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1878*4bdc9457SAndroid Build Coastguard Worker }
1879*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,batch_div_4)1880*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, batch_div_4) {
1881*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1882*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 8; batch_size < 40; batch_size += 4) {
1883*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1884*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1885*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1886*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1887*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1888*4bdc9457SAndroid Build Coastguard Worker }
1889*4bdc9457SAndroid Build Coastguard Worker }
1890*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,batch_lt_4)1891*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, batch_lt_4) {
1892*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1893*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 4; batch_size++) {
1894*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1895*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1896*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1897*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1898*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1899*4bdc9457SAndroid Build Coastguard Worker }
1900*4bdc9457SAndroid Build Coastguard Worker }
1901*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,batch_gt_4)1902*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, batch_gt_4) {
1903*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1904*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 5; batch_size < 8; batch_size++) {
1905*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1906*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1907*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1908*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1909*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1910*4bdc9457SAndroid Build Coastguard Worker }
1911*4bdc9457SAndroid Build Coastguard Worker }
1912*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,scale)1913*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, scale) {
1914*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1915*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
1916*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1917*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1918*4bdc9457SAndroid Build Coastguard Worker .scale(50)
1919*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
1920*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1921*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1922*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1923*4bdc9457SAndroid Build Coastguard Worker }
1924*4bdc9457SAndroid Build Coastguard Worker }
1925*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,input_zero_point)1926*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, input_zero_point) {
1927*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1928*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
1929*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
1930*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1931*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1932*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
1933*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1934*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1935*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1936*4bdc9457SAndroid Build Coastguard Worker }
1937*4bdc9457SAndroid Build Coastguard Worker }
1938*4bdc9457SAndroid Build Coastguard Worker }
1939*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X4,output_zero_point)1940*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X4, output_zero_point) {
1941*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1942*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
1943*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
1944*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1945*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1946*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
1947*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1948*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1949*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x4, xnn_init_qu8_cvt_armsimd32_params);
1950*4bdc9457SAndroid Build Coastguard Worker }
1951*4bdc9457SAndroid Build Coastguard Worker }
1952*4bdc9457SAndroid Build Coastguard Worker }
1953*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM
1954*4bdc9457SAndroid Build Coastguard Worker
1955*4bdc9457SAndroid Build Coastguard Worker
1956*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM
TEST(QU8_VCVT__ARMSIMD32_X8,batch_eq_8)1957*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, batch_eq_8) {
1958*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1959*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1960*4bdc9457SAndroid Build Coastguard Worker .batch_size(8)
1961*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1962*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1963*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
1964*4bdc9457SAndroid Build Coastguard Worker }
1965*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,batch_div_8)1966*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, batch_div_8) {
1967*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1968*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 16; batch_size < 80; batch_size += 8) {
1969*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1970*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1971*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1972*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1973*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
1974*4bdc9457SAndroid Build Coastguard Worker }
1975*4bdc9457SAndroid Build Coastguard Worker }
1976*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,batch_lt_8)1977*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, batch_lt_8) {
1978*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1979*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 8; batch_size++) {
1980*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1981*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1982*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1983*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1984*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
1985*4bdc9457SAndroid Build Coastguard Worker }
1986*4bdc9457SAndroid Build Coastguard Worker }
1987*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,batch_gt_8)1988*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, batch_gt_8) {
1989*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
1990*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 9; batch_size < 16; batch_size++) {
1991*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
1992*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
1993*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
1994*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
1995*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
1996*4bdc9457SAndroid Build Coastguard Worker }
1997*4bdc9457SAndroid Build Coastguard Worker }
1998*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,scale)1999*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, scale) {
2000*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
2001*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2002*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2003*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2004*4bdc9457SAndroid Build Coastguard Worker .scale(50)
2005*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
2006*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2007*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2008*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
2009*4bdc9457SAndroid Build Coastguard Worker }
2010*4bdc9457SAndroid Build Coastguard Worker }
2011*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,input_zero_point)2012*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, input_zero_point) {
2013*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
2014*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
2015*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2016*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2017*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2018*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
2019*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2020*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2021*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
2022*4bdc9457SAndroid Build Coastguard Worker }
2023*4bdc9457SAndroid Build Coastguard Worker }
2024*4bdc9457SAndroid Build Coastguard Worker }
2025*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__ARMSIMD32_X8,output_zero_point)2026*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__ARMSIMD32_X8, output_zero_point) {
2027*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_SIMD32;
2028*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
2029*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 40; batch_size += 7) {
2030*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2031*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2032*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
2033*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2034*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2035*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__armsimd32_x8, xnn_init_qu8_cvt_armsimd32_params);
2036*4bdc9457SAndroid Build Coastguard Worker }
2037*4bdc9457SAndroid Build Coastguard Worker }
2038*4bdc9457SAndroid Build Coastguard Worker }
2039*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM
2040*4bdc9457SAndroid Build Coastguard Worker
2041*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X1,batch_eq_1)2042*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X1, batch_eq_1) {
2043*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2044*4bdc9457SAndroid Build Coastguard Worker .batch_size(1)
2045*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2046*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2047*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x1, xnn_init_qu8_cvt_scalar_params);
2048*4bdc9457SAndroid Build Coastguard Worker }
2049*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X1,batch_gt_1)2050*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X1, batch_gt_1) {
2051*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 2; batch_size < 10; batch_size++) {
2052*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2053*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2054*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2055*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2056*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x1, xnn_init_qu8_cvt_scalar_params);
2057*4bdc9457SAndroid Build Coastguard Worker }
2058*4bdc9457SAndroid Build Coastguard Worker }
2059*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X1,scale)2060*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X1, scale) {
2061*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2062*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2063*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2064*4bdc9457SAndroid Build Coastguard Worker .scale(50)
2065*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
2066*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2067*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2068*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x1, xnn_init_qu8_cvt_scalar_params);
2069*4bdc9457SAndroid Build Coastguard Worker }
2070*4bdc9457SAndroid Build Coastguard Worker }
2071*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X1,input_zero_point)2072*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X1, input_zero_point) {
2073*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
2074*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2075*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2076*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2077*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
2078*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2079*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2080*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x1, xnn_init_qu8_cvt_scalar_params);
2081*4bdc9457SAndroid Build Coastguard Worker }
2082*4bdc9457SAndroid Build Coastguard Worker }
2083*4bdc9457SAndroid Build Coastguard Worker }
2084*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X1,output_zero_point)2085*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X1, output_zero_point) {
2086*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
2087*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 5; batch_size += 1) {
2088*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2089*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2090*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
2091*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2092*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2093*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x1, xnn_init_qu8_cvt_scalar_params);
2094*4bdc9457SAndroid Build Coastguard Worker }
2095*4bdc9457SAndroid Build Coastguard Worker }
2096*4bdc9457SAndroid Build Coastguard Worker }
2097*4bdc9457SAndroid Build Coastguard Worker
2098*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,batch_eq_2)2099*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, batch_eq_2) {
2100*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2101*4bdc9457SAndroid Build Coastguard Worker .batch_size(2)
2102*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2103*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2105*4bdc9457SAndroid Build Coastguard Worker }
2106*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,batch_div_2)2107*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, batch_div_2) {
2108*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 4; batch_size < 20; batch_size += 2) {
2109*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2110*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2111*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2112*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2113*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2114*4bdc9457SAndroid Build Coastguard Worker }
2115*4bdc9457SAndroid Build Coastguard Worker }
2116*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,batch_lt_2)2117*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, batch_lt_2) {
2118*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 2; batch_size++) {
2119*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2120*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2121*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2122*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2123*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2124*4bdc9457SAndroid Build Coastguard Worker }
2125*4bdc9457SAndroid Build Coastguard Worker }
2126*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,batch_gt_2)2127*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, batch_gt_2) {
2128*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 3; batch_size < 4; batch_size++) {
2129*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2130*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2131*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2132*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2133*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2134*4bdc9457SAndroid Build Coastguard Worker }
2135*4bdc9457SAndroid Build Coastguard Worker }
2136*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,scale)2137*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, scale) {
2138*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2139*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2140*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2141*4bdc9457SAndroid Build Coastguard Worker .scale(50)
2142*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
2143*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2144*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2145*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2146*4bdc9457SAndroid Build Coastguard Worker }
2147*4bdc9457SAndroid Build Coastguard Worker }
2148*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,input_zero_point)2149*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, input_zero_point) {
2150*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
2151*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2152*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2153*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2154*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
2155*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2156*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2157*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2158*4bdc9457SAndroid Build Coastguard Worker }
2159*4bdc9457SAndroid Build Coastguard Worker }
2160*4bdc9457SAndroid Build Coastguard Worker }
2161*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X2,output_zero_point)2162*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X2, output_zero_point) {
2163*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
2164*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 10; batch_size += 1) {
2165*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2166*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2167*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
2168*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2169*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2170*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x2, xnn_init_qu8_cvt_scalar_params);
2171*4bdc9457SAndroid Build Coastguard Worker }
2172*4bdc9457SAndroid Build Coastguard Worker }
2173*4bdc9457SAndroid Build Coastguard Worker }
2174*4bdc9457SAndroid Build Coastguard Worker
2175*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,batch_eq_4)2176*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, batch_eq_4) {
2177*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2178*4bdc9457SAndroid Build Coastguard Worker .batch_size(4)
2179*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2180*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2181*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2182*4bdc9457SAndroid Build Coastguard Worker }
2183*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,batch_div_4)2184*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, batch_div_4) {
2185*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 8; batch_size < 40; batch_size += 4) {
2186*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2187*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2188*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2189*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2190*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2191*4bdc9457SAndroid Build Coastguard Worker }
2192*4bdc9457SAndroid Build Coastguard Worker }
2193*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,batch_lt_4)2194*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, batch_lt_4) {
2195*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size < 4; batch_size++) {
2196*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2197*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2198*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2199*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2200*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2201*4bdc9457SAndroid Build Coastguard Worker }
2202*4bdc9457SAndroid Build Coastguard Worker }
2203*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,batch_gt_4)2204*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, batch_gt_4) {
2205*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 5; batch_size < 8; batch_size++) {
2206*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2207*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2208*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2209*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2210*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2211*4bdc9457SAndroid Build Coastguard Worker }
2212*4bdc9457SAndroid Build Coastguard Worker }
2213*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,scale)2214*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, scale) {
2215*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2216*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2217*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2218*4bdc9457SAndroid Build Coastguard Worker .scale(50)
2219*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(100)
2220*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2221*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2222*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2223*4bdc9457SAndroid Build Coastguard Worker }
2224*4bdc9457SAndroid Build Coastguard Worker }
2225*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,input_zero_point)2226*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, input_zero_point) {
2227*4bdc9457SAndroid Build Coastguard Worker for (int16_t input_zero_point = 0; input_zero_point < 5; input_zero_point += 2) {
2228*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2229*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2230*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2231*4bdc9457SAndroid Build Coastguard Worker .input_zero_point(input_zero_point)
2232*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2233*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2234*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2235*4bdc9457SAndroid Build Coastguard Worker }
2236*4bdc9457SAndroid Build Coastguard Worker }
2237*4bdc9457SAndroid Build Coastguard Worker }
2238*4bdc9457SAndroid Build Coastguard Worker
TEST(QU8_VCVT__SCALAR_X4,output_zero_point)2239*4bdc9457SAndroid Build Coastguard Worker TEST(QU8_VCVT__SCALAR_X4, output_zero_point) {
2240*4bdc9457SAndroid Build Coastguard Worker for (int16_t output_zero_point = 0; output_zero_point < 5; output_zero_point += 2) {
2241*4bdc9457SAndroid Build Coastguard Worker for (size_t batch_size = 1; batch_size <= 20; batch_size += 3) {
2242*4bdc9457SAndroid Build Coastguard Worker VCvtMicrokernelTester()
2243*4bdc9457SAndroid Build Coastguard Worker .batch_size(batch_size)
2244*4bdc9457SAndroid Build Coastguard Worker .output_zero_point(output_zero_point)
2245*4bdc9457SAndroid Build Coastguard Worker .qmin(std::numeric_limits<uint8_t>::min())
2246*4bdc9457SAndroid Build Coastguard Worker .qmax(std::numeric_limits<uint8_t>::max())
2247*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_qu8_vcvt_ukernel__scalar_x4, xnn_init_qu8_cvt_scalar_params);
2248*4bdc9457SAndroid Build Coastguard Worker }
2249*4bdc9457SAndroid Build Coastguard Worker }
2250*4bdc9457SAndroid Build Coastguard Worker }
2251