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