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