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