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/f32-raddstoreexpminusmax.yaml
8*4bdc9457SAndroid Build Coastguard Worker // Generator: tools/generate-raddstoreexpminusmax-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/raddstoreexpminusmax.h>
17*4bdc9457SAndroid Build Coastguard Worker #include "raddstoreexpminusmax-microkernel-tester.h"
18*4bdc9457SAndroid Build Coastguard Worker
19*4bdc9457SAndroid Build Coastguard Worker
20*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4,elements_eq_4)21*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4, elements_eq_4) {
22*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
23*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
24*4bdc9457SAndroid Build Coastguard Worker .elements(4)
25*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
26*4bdc9457SAndroid Build Coastguard Worker }
27*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4,elements_div_4)28*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4, elements_div_4) {
29*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
30*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
31*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
32*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
33*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
34*4bdc9457SAndroid Build Coastguard Worker }
35*4bdc9457SAndroid Build Coastguard Worker }
36*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4,elements_lt_4)37*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4, elements_lt_4) {
38*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
39*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
40*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
41*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
42*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
43*4bdc9457SAndroid Build Coastguard Worker }
44*4bdc9457SAndroid Build Coastguard Worker }
45*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4,elements_gt_4)46*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X4, elements_gt_4) {
47*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
48*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
49*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
50*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
51*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
52*4bdc9457SAndroid Build Coastguard Worker }
53*4bdc9457SAndroid Build Coastguard Worker }
54*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
55*4bdc9457SAndroid Build Coastguard Worker
56*4bdc9457SAndroid Build Coastguard Worker
57*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8,elements_eq_8)58*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8, elements_eq_8) {
59*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
60*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
61*4bdc9457SAndroid Build Coastguard Worker .elements(8)
62*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
63*4bdc9457SAndroid Build Coastguard Worker }
64*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8,elements_div_8)65*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8, elements_div_8) {
66*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
67*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
68*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
69*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
70*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
71*4bdc9457SAndroid Build Coastguard Worker }
72*4bdc9457SAndroid Build Coastguard Worker }
73*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8,elements_lt_8)74*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8, elements_lt_8) {
75*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
76*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
77*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
78*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
79*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
80*4bdc9457SAndroid Build Coastguard Worker }
81*4bdc9457SAndroid Build Coastguard Worker }
82*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8,elements_gt_8)83*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8, elements_gt_8) {
84*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
85*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
86*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
87*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
88*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
89*4bdc9457SAndroid Build Coastguard Worker }
90*4bdc9457SAndroid Build Coastguard Worker }
91*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
92*4bdc9457SAndroid Build Coastguard Worker
93*4bdc9457SAndroid Build Coastguard Worker
94*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2,elements_eq_8)95*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2, elements_eq_8) {
96*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
97*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
98*4bdc9457SAndroid Build Coastguard Worker .elements(8)
99*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
100*4bdc9457SAndroid Build Coastguard Worker }
101*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2,elements_div_8)102*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2, elements_div_8) {
103*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
104*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
105*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
106*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
107*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
108*4bdc9457SAndroid Build Coastguard Worker }
109*4bdc9457SAndroid Build Coastguard Worker }
110*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2,elements_lt_8)111*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2, elements_lt_8) {
112*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
113*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
114*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
115*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
116*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
117*4bdc9457SAndroid Build Coastguard Worker }
118*4bdc9457SAndroid Build Coastguard Worker }
119*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2,elements_gt_8)120*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X8_ACC2, elements_gt_8) {
121*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
122*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
123*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
124*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
125*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x8_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
126*4bdc9457SAndroid Build Coastguard Worker }
127*4bdc9457SAndroid Build Coastguard Worker }
128*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
129*4bdc9457SAndroid Build Coastguard Worker
130*4bdc9457SAndroid Build Coastguard Worker
131*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12,elements_eq_12)132*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12, elements_eq_12) {
133*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
134*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
135*4bdc9457SAndroid Build Coastguard Worker .elements(12)
136*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
137*4bdc9457SAndroid Build Coastguard Worker }
138*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12,elements_div_12)139*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12, elements_div_12) {
140*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
141*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
142*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
143*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
144*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
145*4bdc9457SAndroid Build Coastguard Worker }
146*4bdc9457SAndroid Build Coastguard Worker }
147*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12,elements_lt_12)148*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12, elements_lt_12) {
149*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
150*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
151*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
152*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
153*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
154*4bdc9457SAndroid Build Coastguard Worker }
155*4bdc9457SAndroid Build Coastguard Worker }
156*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12,elements_gt_12)157*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12, elements_gt_12) {
158*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
159*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
160*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
161*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
162*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
163*4bdc9457SAndroid Build Coastguard Worker }
164*4bdc9457SAndroid Build Coastguard Worker }
165*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
166*4bdc9457SAndroid Build Coastguard Worker
167*4bdc9457SAndroid Build Coastguard Worker
168*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2,elements_eq_12)169*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2, elements_eq_12) {
170*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
171*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
172*4bdc9457SAndroid Build Coastguard Worker .elements(12)
173*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
174*4bdc9457SAndroid Build Coastguard Worker }
175*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2,elements_div_12)176*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2, elements_div_12) {
177*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
178*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
179*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
180*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
181*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
182*4bdc9457SAndroid Build Coastguard Worker }
183*4bdc9457SAndroid Build Coastguard Worker }
184*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2,elements_lt_12)185*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2, elements_lt_12) {
186*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
187*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
188*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
189*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
190*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
191*4bdc9457SAndroid Build Coastguard Worker }
192*4bdc9457SAndroid Build Coastguard Worker }
193*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2,elements_gt_12)194*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC2, elements_gt_12) {
195*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
196*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
197*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
198*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
199*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
200*4bdc9457SAndroid Build Coastguard Worker }
201*4bdc9457SAndroid Build Coastguard Worker }
202*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
203*4bdc9457SAndroid Build Coastguard Worker
204*4bdc9457SAndroid Build Coastguard Worker
205*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3,elements_eq_12)206*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3, elements_eq_12) {
207*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
208*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
209*4bdc9457SAndroid Build Coastguard Worker .elements(12)
210*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc3, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
211*4bdc9457SAndroid Build Coastguard Worker }
212*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3,elements_div_12)213*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3, elements_div_12) {
214*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
215*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
216*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
217*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
218*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc3, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
219*4bdc9457SAndroid Build Coastguard Worker }
220*4bdc9457SAndroid Build Coastguard Worker }
221*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3,elements_lt_12)222*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3, elements_lt_12) {
223*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
224*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
225*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
226*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
227*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc3, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
228*4bdc9457SAndroid Build Coastguard Worker }
229*4bdc9457SAndroid Build Coastguard Worker }
230*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3,elements_gt_12)231*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X12_ACC3, elements_gt_12) {
232*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
233*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
234*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
235*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
236*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x12_acc3, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
237*4bdc9457SAndroid Build Coastguard Worker }
238*4bdc9457SAndroid Build Coastguard Worker }
239*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
240*4bdc9457SAndroid Build Coastguard Worker
241*4bdc9457SAndroid Build Coastguard Worker
242*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16,elements_eq_16)243*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16, elements_eq_16) {
244*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
245*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
246*4bdc9457SAndroid Build Coastguard Worker .elements(16)
247*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
248*4bdc9457SAndroid Build Coastguard Worker }
249*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16,elements_div_16)250*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16, elements_div_16) {
251*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
252*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
253*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
254*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
255*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
256*4bdc9457SAndroid Build Coastguard Worker }
257*4bdc9457SAndroid Build Coastguard Worker }
258*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16,elements_lt_16)259*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16, elements_lt_16) {
260*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
261*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
262*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
263*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
265*4bdc9457SAndroid Build Coastguard Worker }
266*4bdc9457SAndroid Build Coastguard Worker }
267*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16,elements_gt_16)268*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16, elements_gt_16) {
269*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
270*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
271*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
272*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
273*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
274*4bdc9457SAndroid Build Coastguard Worker }
275*4bdc9457SAndroid Build Coastguard Worker }
276*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
277*4bdc9457SAndroid Build Coastguard Worker
278*4bdc9457SAndroid Build Coastguard Worker
279*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2,elements_eq_16)280*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2, elements_eq_16) {
281*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
282*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
283*4bdc9457SAndroid Build Coastguard Worker .elements(16)
284*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
285*4bdc9457SAndroid Build Coastguard Worker }
286*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2,elements_div_16)287*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2, elements_div_16) {
288*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
289*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
290*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
291*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
292*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
293*4bdc9457SAndroid Build Coastguard Worker }
294*4bdc9457SAndroid Build Coastguard Worker }
295*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2,elements_lt_16)296*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2, elements_lt_16) {
297*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
298*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
299*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
300*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
301*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
302*4bdc9457SAndroid Build Coastguard Worker }
303*4bdc9457SAndroid Build Coastguard Worker }
304*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2,elements_gt_16)305*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC2, elements_gt_16) {
306*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
307*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
308*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
309*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
310*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
311*4bdc9457SAndroid Build Coastguard Worker }
312*4bdc9457SAndroid Build Coastguard Worker }
313*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
314*4bdc9457SAndroid Build Coastguard Worker
315*4bdc9457SAndroid Build Coastguard Worker
316*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4,elements_eq_16)317*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4, elements_eq_16) {
318*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
319*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
320*4bdc9457SAndroid Build Coastguard Worker .elements(16)
321*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
322*4bdc9457SAndroid Build Coastguard Worker }
323*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4,elements_div_16)324*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4, elements_div_16) {
325*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
326*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
327*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
328*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
329*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
330*4bdc9457SAndroid Build Coastguard Worker }
331*4bdc9457SAndroid Build Coastguard Worker }
332*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4,elements_lt_16)333*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4, elements_lt_16) {
334*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
335*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
336*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
337*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
338*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
339*4bdc9457SAndroid Build Coastguard Worker }
340*4bdc9457SAndroid Build Coastguard Worker }
341*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4,elements_gt_16)342*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X16_ACC4, elements_gt_16) {
343*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
344*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
345*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
346*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
347*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x16_acc4, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
348*4bdc9457SAndroid Build Coastguard Worker }
349*4bdc9457SAndroid Build Coastguard Worker }
350*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
351*4bdc9457SAndroid Build Coastguard Worker
352*4bdc9457SAndroid Build Coastguard Worker
353*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20,elements_eq_20)354*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20, elements_eq_20) {
355*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
356*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
357*4bdc9457SAndroid Build Coastguard Worker .elements(20)
358*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
359*4bdc9457SAndroid Build Coastguard Worker }
360*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20,elements_div_20)361*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20, elements_div_20) {
362*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
363*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
364*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
365*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
366*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
367*4bdc9457SAndroid Build Coastguard Worker }
368*4bdc9457SAndroid Build Coastguard Worker }
369*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20,elements_lt_20)370*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20, elements_lt_20) {
371*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
372*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
373*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
374*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
375*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
376*4bdc9457SAndroid Build Coastguard Worker }
377*4bdc9457SAndroid Build Coastguard Worker }
378*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20,elements_gt_20)379*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20, elements_gt_20) {
380*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
381*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
382*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
383*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
384*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
385*4bdc9457SAndroid Build Coastguard Worker }
386*4bdc9457SAndroid Build Coastguard Worker }
387*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
388*4bdc9457SAndroid Build Coastguard Worker
389*4bdc9457SAndroid Build Coastguard Worker
390*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2,elements_eq_20)391*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2, elements_eq_20) {
392*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
393*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
394*4bdc9457SAndroid Build Coastguard Worker .elements(20)
395*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
396*4bdc9457SAndroid Build Coastguard Worker }
397*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2,elements_div_20)398*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2, elements_div_20) {
399*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
400*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
401*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
402*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
404*4bdc9457SAndroid Build Coastguard Worker }
405*4bdc9457SAndroid Build Coastguard Worker }
406*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2,elements_lt_20)407*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2, elements_lt_20) {
408*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
409*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
410*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
411*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
412*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
413*4bdc9457SAndroid Build Coastguard Worker }
414*4bdc9457SAndroid Build Coastguard Worker }
415*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2,elements_gt_20)416*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC2, elements_gt_20) {
417*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
418*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
419*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
420*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
421*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc2, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
422*4bdc9457SAndroid Build Coastguard Worker }
423*4bdc9457SAndroid Build Coastguard Worker }
424*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
425*4bdc9457SAndroid Build Coastguard Worker
426*4bdc9457SAndroid Build Coastguard Worker
427*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5,elements_eq_20)428*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5, elements_eq_20) {
429*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
430*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
431*4bdc9457SAndroid Build Coastguard Worker .elements(20)
432*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc5, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
433*4bdc9457SAndroid Build Coastguard Worker }
434*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5,elements_div_20)435*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5, elements_div_20) {
436*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
437*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
438*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
439*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
440*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc5, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
441*4bdc9457SAndroid Build Coastguard Worker }
442*4bdc9457SAndroid Build Coastguard Worker }
443*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5,elements_lt_20)444*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5, elements_lt_20) {
445*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
446*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
447*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
448*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
449*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc5, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
450*4bdc9457SAndroid Build Coastguard Worker }
451*4bdc9457SAndroid Build Coastguard Worker }
452*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5,elements_gt_20)453*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_LUT64_P2_X20_ACC5, elements_gt_20) {
454*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
455*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
456*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
457*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
458*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_lut64_p2_x20_acc5, xnn_init_f32_expminus_neon_rr2_lut64_p2_params);
459*4bdc9457SAndroid Build Coastguard Worker }
460*4bdc9457SAndroid Build Coastguard Worker }
461*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
462*4bdc9457SAndroid Build Coastguard Worker
463*4bdc9457SAndroid Build Coastguard Worker
464*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4,elements_eq_4)465*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4, elements_eq_4) {
466*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
467*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
468*4bdc9457SAndroid Build Coastguard Worker .elements(4)
469*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x4, xnn_init_f32_expminus_neon_rr2_p5_params);
470*4bdc9457SAndroid Build Coastguard Worker }
471*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4,elements_div_4)472*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4, elements_div_4) {
473*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
474*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
475*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
476*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
477*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x4, xnn_init_f32_expminus_neon_rr2_p5_params);
478*4bdc9457SAndroid Build Coastguard Worker }
479*4bdc9457SAndroid Build Coastguard Worker }
480*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4,elements_lt_4)481*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4, elements_lt_4) {
482*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
483*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
484*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
485*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
486*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x4, xnn_init_f32_expminus_neon_rr2_p5_params);
487*4bdc9457SAndroid Build Coastguard Worker }
488*4bdc9457SAndroid Build Coastguard Worker }
489*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4,elements_gt_4)490*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X4, elements_gt_4) {
491*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
492*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
493*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
494*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x4, xnn_init_f32_expminus_neon_rr2_p5_params);
496*4bdc9457SAndroid Build Coastguard Worker }
497*4bdc9457SAndroid Build Coastguard Worker }
498*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
499*4bdc9457SAndroid Build Coastguard Worker
500*4bdc9457SAndroid Build Coastguard Worker
501*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8,elements_eq_8)502*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8, elements_eq_8) {
503*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
504*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
505*4bdc9457SAndroid Build Coastguard Worker .elements(8)
506*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8, xnn_init_f32_expminus_neon_rr2_p5_params);
507*4bdc9457SAndroid Build Coastguard Worker }
508*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8,elements_div_8)509*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8, elements_div_8) {
510*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
511*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
512*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
513*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
514*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8, xnn_init_f32_expminus_neon_rr2_p5_params);
515*4bdc9457SAndroid Build Coastguard Worker }
516*4bdc9457SAndroid Build Coastguard Worker }
517*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8,elements_lt_8)518*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8, elements_lt_8) {
519*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
520*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
521*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
522*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
523*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8, xnn_init_f32_expminus_neon_rr2_p5_params);
524*4bdc9457SAndroid Build Coastguard Worker }
525*4bdc9457SAndroid Build Coastguard Worker }
526*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8,elements_gt_8)527*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8, elements_gt_8) {
528*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
529*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
530*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
531*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
532*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8, xnn_init_f32_expminus_neon_rr2_p5_params);
533*4bdc9457SAndroid Build Coastguard Worker }
534*4bdc9457SAndroid Build Coastguard Worker }
535*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
536*4bdc9457SAndroid Build Coastguard Worker
537*4bdc9457SAndroid Build Coastguard Worker
538*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2,elements_eq_8)539*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2, elements_eq_8) {
540*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
541*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
542*4bdc9457SAndroid Build Coastguard Worker .elements(8)
543*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
544*4bdc9457SAndroid Build Coastguard Worker }
545*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2,elements_div_8)546*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2, elements_div_8) {
547*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
548*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
549*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
550*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
551*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
552*4bdc9457SAndroid Build Coastguard Worker }
553*4bdc9457SAndroid Build Coastguard Worker }
554*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2,elements_lt_8)555*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2, elements_lt_8) {
556*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
557*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
558*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
559*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
560*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
561*4bdc9457SAndroid Build Coastguard Worker }
562*4bdc9457SAndroid Build Coastguard Worker }
563*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2,elements_gt_8)564*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X8_ACC2, elements_gt_8) {
565*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
566*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
567*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
568*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
569*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x8_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
570*4bdc9457SAndroid Build Coastguard Worker }
571*4bdc9457SAndroid Build Coastguard Worker }
572*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
573*4bdc9457SAndroid Build Coastguard Worker
574*4bdc9457SAndroid Build Coastguard Worker
575*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12,elements_eq_12)576*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12, elements_eq_12) {
577*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
578*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
579*4bdc9457SAndroid Build Coastguard Worker .elements(12)
580*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12, xnn_init_f32_expminus_neon_rr2_p5_params);
581*4bdc9457SAndroid Build Coastguard Worker }
582*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12,elements_div_12)583*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12, elements_div_12) {
584*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
585*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
586*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
587*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
588*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12, xnn_init_f32_expminus_neon_rr2_p5_params);
589*4bdc9457SAndroid Build Coastguard Worker }
590*4bdc9457SAndroid Build Coastguard Worker }
591*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12,elements_lt_12)592*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12, elements_lt_12) {
593*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
594*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
595*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
596*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
597*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12, xnn_init_f32_expminus_neon_rr2_p5_params);
598*4bdc9457SAndroid Build Coastguard Worker }
599*4bdc9457SAndroid Build Coastguard Worker }
600*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12,elements_gt_12)601*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12, elements_gt_12) {
602*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
603*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
604*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
605*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
606*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12, xnn_init_f32_expminus_neon_rr2_p5_params);
607*4bdc9457SAndroid Build Coastguard Worker }
608*4bdc9457SAndroid Build Coastguard Worker }
609*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
610*4bdc9457SAndroid Build Coastguard Worker
611*4bdc9457SAndroid Build Coastguard Worker
612*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2,elements_eq_12)613*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2, elements_eq_12) {
614*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
615*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
616*4bdc9457SAndroid Build Coastguard Worker .elements(12)
617*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
618*4bdc9457SAndroid Build Coastguard Worker }
619*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2,elements_div_12)620*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2, elements_div_12) {
621*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
622*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
623*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
624*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
625*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
626*4bdc9457SAndroid Build Coastguard Worker }
627*4bdc9457SAndroid Build Coastguard Worker }
628*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2,elements_lt_12)629*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2, elements_lt_12) {
630*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
631*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
632*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
633*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
634*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
635*4bdc9457SAndroid Build Coastguard Worker }
636*4bdc9457SAndroid Build Coastguard Worker }
637*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2,elements_gt_12)638*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC2, elements_gt_12) {
639*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
640*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
641*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
642*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
643*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
644*4bdc9457SAndroid Build Coastguard Worker }
645*4bdc9457SAndroid Build Coastguard Worker }
646*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
647*4bdc9457SAndroid Build Coastguard Worker
648*4bdc9457SAndroid Build Coastguard Worker
649*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3,elements_eq_12)650*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3, elements_eq_12) {
651*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
652*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
653*4bdc9457SAndroid Build Coastguard Worker .elements(12)
654*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc3, xnn_init_f32_expminus_neon_rr2_p5_params);
655*4bdc9457SAndroid Build Coastguard Worker }
656*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3,elements_div_12)657*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3, elements_div_12) {
658*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
659*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
660*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
661*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
662*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc3, xnn_init_f32_expminus_neon_rr2_p5_params);
663*4bdc9457SAndroid Build Coastguard Worker }
664*4bdc9457SAndroid Build Coastguard Worker }
665*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3,elements_lt_12)666*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3, elements_lt_12) {
667*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
668*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
669*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
670*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
671*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc3, xnn_init_f32_expminus_neon_rr2_p5_params);
672*4bdc9457SAndroid Build Coastguard Worker }
673*4bdc9457SAndroid Build Coastguard Worker }
674*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3,elements_gt_12)675*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X12_ACC3, elements_gt_12) {
676*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
677*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
678*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
679*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
680*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x12_acc3, xnn_init_f32_expminus_neon_rr2_p5_params);
681*4bdc9457SAndroid Build Coastguard Worker }
682*4bdc9457SAndroid Build Coastguard Worker }
683*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
684*4bdc9457SAndroid Build Coastguard Worker
685*4bdc9457SAndroid Build Coastguard Worker
686*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16,elements_eq_16)687*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16, elements_eq_16) {
688*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
689*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
690*4bdc9457SAndroid Build Coastguard Worker .elements(16)
691*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16, xnn_init_f32_expminus_neon_rr2_p5_params);
692*4bdc9457SAndroid Build Coastguard Worker }
693*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16,elements_div_16)694*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16, elements_div_16) {
695*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
696*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
697*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
698*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
699*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16, xnn_init_f32_expminus_neon_rr2_p5_params);
700*4bdc9457SAndroid Build Coastguard Worker }
701*4bdc9457SAndroid Build Coastguard Worker }
702*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16,elements_lt_16)703*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16, elements_lt_16) {
704*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
705*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
706*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
707*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
708*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16, xnn_init_f32_expminus_neon_rr2_p5_params);
709*4bdc9457SAndroid Build Coastguard Worker }
710*4bdc9457SAndroid Build Coastguard Worker }
711*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16,elements_gt_16)712*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16, elements_gt_16) {
713*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
714*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
715*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
716*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
717*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16, xnn_init_f32_expminus_neon_rr2_p5_params);
718*4bdc9457SAndroid Build Coastguard Worker }
719*4bdc9457SAndroid Build Coastguard Worker }
720*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
721*4bdc9457SAndroid Build Coastguard Worker
722*4bdc9457SAndroid Build Coastguard Worker
723*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2,elements_eq_16)724*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2, elements_eq_16) {
725*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
726*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
727*4bdc9457SAndroid Build Coastguard Worker .elements(16)
728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
729*4bdc9457SAndroid Build Coastguard Worker }
730*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2,elements_div_16)731*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2, elements_div_16) {
732*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
733*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
734*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
735*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
736*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
737*4bdc9457SAndroid Build Coastguard Worker }
738*4bdc9457SAndroid Build Coastguard Worker }
739*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2,elements_lt_16)740*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2, elements_lt_16) {
741*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
742*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
743*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
744*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
745*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
746*4bdc9457SAndroid Build Coastguard Worker }
747*4bdc9457SAndroid Build Coastguard Worker }
748*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2,elements_gt_16)749*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC2, elements_gt_16) {
750*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
751*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
752*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
753*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
754*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
755*4bdc9457SAndroid Build Coastguard Worker }
756*4bdc9457SAndroid Build Coastguard Worker }
757*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
758*4bdc9457SAndroid Build Coastguard Worker
759*4bdc9457SAndroid Build Coastguard Worker
760*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4,elements_eq_16)761*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4, elements_eq_16) {
762*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
763*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
764*4bdc9457SAndroid Build Coastguard Worker .elements(16)
765*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc4, xnn_init_f32_expminus_neon_rr2_p5_params);
766*4bdc9457SAndroid Build Coastguard Worker }
767*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4,elements_div_16)768*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4, elements_div_16) {
769*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
770*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
771*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
772*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
773*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc4, xnn_init_f32_expminus_neon_rr2_p5_params);
774*4bdc9457SAndroid Build Coastguard Worker }
775*4bdc9457SAndroid Build Coastguard Worker }
776*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4,elements_lt_16)777*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4, elements_lt_16) {
778*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
779*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
780*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
781*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
782*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc4, xnn_init_f32_expminus_neon_rr2_p5_params);
783*4bdc9457SAndroid Build Coastguard Worker }
784*4bdc9457SAndroid Build Coastguard Worker }
785*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4,elements_gt_16)786*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X16_ACC4, elements_gt_16) {
787*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
788*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
789*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
790*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
791*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x16_acc4, xnn_init_f32_expminus_neon_rr2_p5_params);
792*4bdc9457SAndroid Build Coastguard Worker }
793*4bdc9457SAndroid Build Coastguard Worker }
794*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
795*4bdc9457SAndroid Build Coastguard Worker
796*4bdc9457SAndroid Build Coastguard Worker
797*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20,elements_eq_20)798*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20, elements_eq_20) {
799*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
800*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
801*4bdc9457SAndroid Build Coastguard Worker .elements(20)
802*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20, xnn_init_f32_expminus_neon_rr2_p5_params);
803*4bdc9457SAndroid Build Coastguard Worker }
804*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20,elements_div_20)805*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20, elements_div_20) {
806*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
807*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
808*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
809*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
810*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20, xnn_init_f32_expminus_neon_rr2_p5_params);
811*4bdc9457SAndroid Build Coastguard Worker }
812*4bdc9457SAndroid Build Coastguard Worker }
813*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20,elements_lt_20)814*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20, elements_lt_20) {
815*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
816*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
817*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
818*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
819*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20, xnn_init_f32_expminus_neon_rr2_p5_params);
820*4bdc9457SAndroid Build Coastguard Worker }
821*4bdc9457SAndroid Build Coastguard Worker }
822*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20,elements_gt_20)823*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20, elements_gt_20) {
824*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
825*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
826*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
827*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
828*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20, xnn_init_f32_expminus_neon_rr2_p5_params);
829*4bdc9457SAndroid Build Coastguard Worker }
830*4bdc9457SAndroid Build Coastguard Worker }
831*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
832*4bdc9457SAndroid Build Coastguard Worker
833*4bdc9457SAndroid Build Coastguard Worker
834*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2,elements_eq_20)835*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2, elements_eq_20) {
836*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
837*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
838*4bdc9457SAndroid Build Coastguard Worker .elements(20)
839*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
840*4bdc9457SAndroid Build Coastguard Worker }
841*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2,elements_div_20)842*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2, elements_div_20) {
843*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
844*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
845*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
846*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
847*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
848*4bdc9457SAndroid Build Coastguard Worker }
849*4bdc9457SAndroid Build Coastguard Worker }
850*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2,elements_lt_20)851*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2, elements_lt_20) {
852*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
853*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
854*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
855*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
856*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
857*4bdc9457SAndroid Build Coastguard Worker }
858*4bdc9457SAndroid Build Coastguard Worker }
859*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2,elements_gt_20)860*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC2, elements_gt_20) {
861*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
862*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
863*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
864*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
865*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc2, xnn_init_f32_expminus_neon_rr2_p5_params);
866*4bdc9457SAndroid Build Coastguard Worker }
867*4bdc9457SAndroid Build Coastguard Worker }
868*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
869*4bdc9457SAndroid Build Coastguard Worker
870*4bdc9457SAndroid Build Coastguard Worker
871*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5,elements_eq_20)872*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5, elements_eq_20) {
873*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
874*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
875*4bdc9457SAndroid Build Coastguard Worker .elements(20)
876*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc5, xnn_init_f32_expminus_neon_rr2_p5_params);
877*4bdc9457SAndroid Build Coastguard Worker }
878*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5,elements_div_20)879*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5, elements_div_20) {
880*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
881*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
882*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
883*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
884*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc5, xnn_init_f32_expminus_neon_rr2_p5_params);
885*4bdc9457SAndroid Build Coastguard Worker }
886*4bdc9457SAndroid Build Coastguard Worker }
887*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5,elements_lt_20)888*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5, elements_lt_20) {
889*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
890*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
891*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
892*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
893*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc5, xnn_init_f32_expminus_neon_rr2_p5_params);
894*4bdc9457SAndroid Build Coastguard Worker }
895*4bdc9457SAndroid Build Coastguard Worker }
896*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5,elements_gt_20)897*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEON_RR2_P5_X20_ACC5, elements_gt_20) {
898*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON;
899*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
900*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
901*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
902*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neon_rr2_p5_x20_acc5, xnn_init_f32_expminus_neon_rr2_p5_params);
903*4bdc9457SAndroid Build Coastguard Worker }
904*4bdc9457SAndroid Build Coastguard Worker }
905*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
906*4bdc9457SAndroid Build Coastguard Worker
907*4bdc9457SAndroid Build Coastguard Worker
908*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4,elements_eq_4)909*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4, elements_eq_4) {
910*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
911*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
912*4bdc9457SAndroid Build Coastguard Worker .elements(4)
913*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
914*4bdc9457SAndroid Build Coastguard Worker }
915*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4,elements_div_4)916*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4, elements_div_4) {
917*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
918*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
919*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
920*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
921*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
922*4bdc9457SAndroid Build Coastguard Worker }
923*4bdc9457SAndroid Build Coastguard Worker }
924*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4,elements_lt_4)925*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4, elements_lt_4) {
926*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
927*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
928*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
929*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
930*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
931*4bdc9457SAndroid Build Coastguard Worker }
932*4bdc9457SAndroid Build Coastguard Worker }
933*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4,elements_gt_4)934*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X4, elements_gt_4) {
935*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
936*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
937*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
938*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
939*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
940*4bdc9457SAndroid Build Coastguard Worker }
941*4bdc9457SAndroid Build Coastguard Worker }
942*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
943*4bdc9457SAndroid Build Coastguard Worker
944*4bdc9457SAndroid Build Coastguard Worker
945*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8,elements_eq_8)946*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8, elements_eq_8) {
947*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
948*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
949*4bdc9457SAndroid Build Coastguard Worker .elements(8)
950*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
951*4bdc9457SAndroid Build Coastguard Worker }
952*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8,elements_div_8)953*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8, elements_div_8) {
954*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
955*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
956*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
957*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
958*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
959*4bdc9457SAndroid Build Coastguard Worker }
960*4bdc9457SAndroid Build Coastguard Worker }
961*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8,elements_lt_8)962*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8, elements_lt_8) {
963*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
964*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
965*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
966*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
967*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
968*4bdc9457SAndroid Build Coastguard Worker }
969*4bdc9457SAndroid Build Coastguard Worker }
970*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8,elements_gt_8)971*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8, elements_gt_8) {
972*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
973*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
974*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
975*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
976*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
977*4bdc9457SAndroid Build Coastguard Worker }
978*4bdc9457SAndroid Build Coastguard Worker }
979*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
980*4bdc9457SAndroid Build Coastguard Worker
981*4bdc9457SAndroid Build Coastguard Worker
982*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2,elements_eq_8)983*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2, elements_eq_8) {
984*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
985*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
986*4bdc9457SAndroid Build Coastguard Worker .elements(8)
987*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
988*4bdc9457SAndroid Build Coastguard Worker }
989*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2,elements_div_8)990*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2, elements_div_8) {
991*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
992*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
993*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
994*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
995*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
996*4bdc9457SAndroid Build Coastguard Worker }
997*4bdc9457SAndroid Build Coastguard Worker }
998*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2,elements_lt_8)999*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2, elements_lt_8) {
1000*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1001*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
1002*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1003*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1004*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1005*4bdc9457SAndroid Build Coastguard Worker }
1006*4bdc9457SAndroid Build Coastguard Worker }
1007*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2,elements_gt_8)1008*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X8_ACC2, elements_gt_8) {
1009*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1010*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
1011*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1012*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1013*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1014*4bdc9457SAndroid Build Coastguard Worker }
1015*4bdc9457SAndroid Build Coastguard Worker }
1016*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1017*4bdc9457SAndroid Build Coastguard Worker
1018*4bdc9457SAndroid Build Coastguard Worker
1019*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12,elements_eq_12)1020*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12, elements_eq_12) {
1021*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1022*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1023*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1024*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1025*4bdc9457SAndroid Build Coastguard Worker }
1026*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12,elements_div_12)1027*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12, elements_div_12) {
1028*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1029*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1030*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1031*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1032*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1033*4bdc9457SAndroid Build Coastguard Worker }
1034*4bdc9457SAndroid Build Coastguard Worker }
1035*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12,elements_lt_12)1036*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12, elements_lt_12) {
1037*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1038*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1039*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1040*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1041*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1042*4bdc9457SAndroid Build Coastguard Worker }
1043*4bdc9457SAndroid Build Coastguard Worker }
1044*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12,elements_gt_12)1045*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12, elements_gt_12) {
1046*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1047*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1048*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1049*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1050*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1051*4bdc9457SAndroid Build Coastguard Worker }
1052*4bdc9457SAndroid Build Coastguard Worker }
1053*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1054*4bdc9457SAndroid Build Coastguard Worker
1055*4bdc9457SAndroid Build Coastguard Worker
1056*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2,elements_eq_12)1057*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2, elements_eq_12) {
1058*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1059*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1060*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1061*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1062*4bdc9457SAndroid Build Coastguard Worker }
1063*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2,elements_div_12)1064*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2, elements_div_12) {
1065*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1066*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1067*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1068*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1069*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1070*4bdc9457SAndroid Build Coastguard Worker }
1071*4bdc9457SAndroid Build Coastguard Worker }
1072*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2,elements_lt_12)1073*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2, elements_lt_12) {
1074*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1075*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1076*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1077*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1078*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1079*4bdc9457SAndroid Build Coastguard Worker }
1080*4bdc9457SAndroid Build Coastguard Worker }
1081*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2,elements_gt_12)1082*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC2, elements_gt_12) {
1083*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1084*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1085*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1086*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1087*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1088*4bdc9457SAndroid Build Coastguard Worker }
1089*4bdc9457SAndroid Build Coastguard Worker }
1090*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1091*4bdc9457SAndroid Build Coastguard Worker
1092*4bdc9457SAndroid Build Coastguard Worker
1093*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3,elements_eq_12)1094*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3, elements_eq_12) {
1095*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1096*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1097*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1098*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1099*4bdc9457SAndroid Build Coastguard Worker }
1100*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3,elements_div_12)1101*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3, elements_div_12) {
1102*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1103*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1104*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1105*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1106*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1107*4bdc9457SAndroid Build Coastguard Worker }
1108*4bdc9457SAndroid Build Coastguard Worker }
1109*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3,elements_lt_12)1110*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3, elements_lt_12) {
1111*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1112*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1113*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1114*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1115*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1116*4bdc9457SAndroid Build Coastguard Worker }
1117*4bdc9457SAndroid Build Coastguard Worker }
1118*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3,elements_gt_12)1119*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X12_ACC3, elements_gt_12) {
1120*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1121*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1122*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1123*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1124*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1125*4bdc9457SAndroid Build Coastguard Worker }
1126*4bdc9457SAndroid Build Coastguard Worker }
1127*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1128*4bdc9457SAndroid Build Coastguard Worker
1129*4bdc9457SAndroid Build Coastguard Worker
1130*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16,elements_eq_16)1131*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16, elements_eq_16) {
1132*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1133*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1134*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1135*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1136*4bdc9457SAndroid Build Coastguard Worker }
1137*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16,elements_div_16)1138*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16, elements_div_16) {
1139*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1140*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1141*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1142*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1143*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1144*4bdc9457SAndroid Build Coastguard Worker }
1145*4bdc9457SAndroid Build Coastguard Worker }
1146*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16,elements_lt_16)1147*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16, elements_lt_16) {
1148*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1149*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1150*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1151*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1152*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1153*4bdc9457SAndroid Build Coastguard Worker }
1154*4bdc9457SAndroid Build Coastguard Worker }
1155*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16,elements_gt_16)1156*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16, elements_gt_16) {
1157*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1158*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1159*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1160*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1161*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1162*4bdc9457SAndroid Build Coastguard Worker }
1163*4bdc9457SAndroid Build Coastguard Worker }
1164*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1165*4bdc9457SAndroid Build Coastguard Worker
1166*4bdc9457SAndroid Build Coastguard Worker
1167*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2,elements_eq_16)1168*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2, elements_eq_16) {
1169*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1170*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1171*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1172*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1173*4bdc9457SAndroid Build Coastguard Worker }
1174*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2,elements_div_16)1175*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2, elements_div_16) {
1176*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1177*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1178*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1179*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1180*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1181*4bdc9457SAndroid Build Coastguard Worker }
1182*4bdc9457SAndroid Build Coastguard Worker }
1183*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2,elements_lt_16)1184*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2, elements_lt_16) {
1185*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1186*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1187*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1188*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1189*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1190*4bdc9457SAndroid Build Coastguard Worker }
1191*4bdc9457SAndroid Build Coastguard Worker }
1192*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2,elements_gt_16)1193*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC2, elements_gt_16) {
1194*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1195*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1196*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1197*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1198*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1199*4bdc9457SAndroid Build Coastguard Worker }
1200*4bdc9457SAndroid Build Coastguard Worker }
1201*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1202*4bdc9457SAndroid Build Coastguard Worker
1203*4bdc9457SAndroid Build Coastguard Worker
1204*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4,elements_eq_16)1205*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4, elements_eq_16) {
1206*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1207*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1208*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1209*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1210*4bdc9457SAndroid Build Coastguard Worker }
1211*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4,elements_div_16)1212*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4, elements_div_16) {
1213*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1214*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1215*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1216*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1217*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1218*4bdc9457SAndroid Build Coastguard Worker }
1219*4bdc9457SAndroid Build Coastguard Worker }
1220*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4,elements_lt_16)1221*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4, elements_lt_16) {
1222*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1223*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1224*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1225*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1226*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1227*4bdc9457SAndroid Build Coastguard Worker }
1228*4bdc9457SAndroid Build Coastguard Worker }
1229*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4,elements_gt_16)1230*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X16_ACC4, elements_gt_16) {
1231*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1232*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1233*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1234*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1235*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1236*4bdc9457SAndroid Build Coastguard Worker }
1237*4bdc9457SAndroid Build Coastguard Worker }
1238*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1239*4bdc9457SAndroid Build Coastguard Worker
1240*4bdc9457SAndroid Build Coastguard Worker
1241*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20,elements_eq_20)1242*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20, elements_eq_20) {
1243*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1244*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1245*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1246*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1247*4bdc9457SAndroid Build Coastguard Worker }
1248*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20,elements_div_20)1249*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20, elements_div_20) {
1250*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1251*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1252*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1253*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1254*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1255*4bdc9457SAndroid Build Coastguard Worker }
1256*4bdc9457SAndroid Build Coastguard Worker }
1257*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20,elements_lt_20)1258*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20, elements_lt_20) {
1259*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1260*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1261*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1262*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1263*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1264*4bdc9457SAndroid Build Coastguard Worker }
1265*4bdc9457SAndroid Build Coastguard Worker }
1266*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20,elements_gt_20)1267*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20, elements_gt_20) {
1268*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1269*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1270*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1271*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1272*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1273*4bdc9457SAndroid Build Coastguard Worker }
1274*4bdc9457SAndroid Build Coastguard Worker }
1275*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1276*4bdc9457SAndroid Build Coastguard Worker
1277*4bdc9457SAndroid Build Coastguard Worker
1278*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2,elements_eq_20)1279*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2, elements_eq_20) {
1280*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1281*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1282*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1283*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1284*4bdc9457SAndroid Build Coastguard Worker }
1285*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2,elements_div_20)1286*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2, elements_div_20) {
1287*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1288*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1289*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1290*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1291*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1292*4bdc9457SAndroid Build Coastguard Worker }
1293*4bdc9457SAndroid Build Coastguard Worker }
1294*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2,elements_lt_20)1295*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2, elements_lt_20) {
1296*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1297*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1298*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1299*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1300*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1301*4bdc9457SAndroid Build Coastguard Worker }
1302*4bdc9457SAndroid Build Coastguard Worker }
1303*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2,elements_gt_20)1304*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC2, elements_gt_20) {
1305*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1306*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1307*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1308*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1309*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1310*4bdc9457SAndroid Build Coastguard Worker }
1311*4bdc9457SAndroid Build Coastguard Worker }
1312*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1313*4bdc9457SAndroid Build Coastguard Worker
1314*4bdc9457SAndroid Build Coastguard Worker
1315*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5,elements_eq_20)1316*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5, elements_eq_20) {
1317*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1318*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1319*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1320*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1321*4bdc9457SAndroid Build Coastguard Worker }
1322*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5,elements_div_20)1323*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5, elements_div_20) {
1324*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1325*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1326*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1327*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1328*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1329*4bdc9457SAndroid Build Coastguard Worker }
1330*4bdc9457SAndroid Build Coastguard Worker }
1331*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5,elements_lt_20)1332*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5, elements_lt_20) {
1333*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1334*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1335*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1336*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1337*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1338*4bdc9457SAndroid Build Coastguard Worker }
1339*4bdc9457SAndroid Build Coastguard Worker }
1340*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5,elements_gt_20)1341*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_LUT64_P2_X20_ACC5, elements_gt_20) {
1342*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1343*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1344*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1345*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1346*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_lut64_p2_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_lut64_p2_params);
1347*4bdc9457SAndroid Build Coastguard Worker }
1348*4bdc9457SAndroid Build Coastguard Worker }
1349*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1350*4bdc9457SAndroid Build Coastguard Worker
1351*4bdc9457SAndroid Build Coastguard Worker
1352*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4,elements_eq_4)1353*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4, elements_eq_4) {
1354*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1355*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1356*4bdc9457SAndroid Build Coastguard Worker .elements(4)
1357*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1358*4bdc9457SAndroid Build Coastguard Worker }
1359*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4,elements_div_4)1360*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4, elements_div_4) {
1361*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1362*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
1363*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1364*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1365*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1366*4bdc9457SAndroid Build Coastguard Worker }
1367*4bdc9457SAndroid Build Coastguard Worker }
1368*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4,elements_lt_4)1369*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4, elements_lt_4) {
1370*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1371*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
1372*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1373*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1374*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1375*4bdc9457SAndroid Build Coastguard Worker }
1376*4bdc9457SAndroid Build Coastguard Worker }
1377*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4,elements_gt_4)1378*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X4, elements_gt_4) {
1379*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1380*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
1381*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1382*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1383*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1384*4bdc9457SAndroid Build Coastguard Worker }
1385*4bdc9457SAndroid Build Coastguard Worker }
1386*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1387*4bdc9457SAndroid Build Coastguard Worker
1388*4bdc9457SAndroid Build Coastguard Worker
1389*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8,elements_eq_8)1390*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8, elements_eq_8) {
1391*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1392*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1393*4bdc9457SAndroid Build Coastguard Worker .elements(8)
1394*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1395*4bdc9457SAndroid Build Coastguard Worker }
1396*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8,elements_div_8)1397*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8, elements_div_8) {
1398*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1399*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
1400*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1401*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1402*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1403*4bdc9457SAndroid Build Coastguard Worker }
1404*4bdc9457SAndroid Build Coastguard Worker }
1405*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8,elements_lt_8)1406*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8, elements_lt_8) {
1407*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1408*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
1409*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1410*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1412*4bdc9457SAndroid Build Coastguard Worker }
1413*4bdc9457SAndroid Build Coastguard Worker }
1414*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8,elements_gt_8)1415*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8, elements_gt_8) {
1416*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1417*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
1418*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1419*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1420*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1421*4bdc9457SAndroid Build Coastguard Worker }
1422*4bdc9457SAndroid Build Coastguard Worker }
1423*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1424*4bdc9457SAndroid Build Coastguard Worker
1425*4bdc9457SAndroid Build Coastguard Worker
1426*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2,elements_eq_8)1427*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2, elements_eq_8) {
1428*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1429*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1430*4bdc9457SAndroid Build Coastguard Worker .elements(8)
1431*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1432*4bdc9457SAndroid Build Coastguard Worker }
1433*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2,elements_div_8)1434*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2, elements_div_8) {
1435*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1436*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
1437*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1438*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1439*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1440*4bdc9457SAndroid Build Coastguard Worker }
1441*4bdc9457SAndroid Build Coastguard Worker }
1442*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2,elements_lt_8)1443*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2, elements_lt_8) {
1444*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1445*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
1446*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1447*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1448*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1449*4bdc9457SAndroid Build Coastguard Worker }
1450*4bdc9457SAndroid Build Coastguard Worker }
1451*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2,elements_gt_8)1452*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X8_ACC2, elements_gt_8) {
1453*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1454*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
1455*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1456*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1457*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x8_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1458*4bdc9457SAndroid Build Coastguard Worker }
1459*4bdc9457SAndroid Build Coastguard Worker }
1460*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1461*4bdc9457SAndroid Build Coastguard Worker
1462*4bdc9457SAndroid Build Coastguard Worker
1463*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12,elements_eq_12)1464*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12, elements_eq_12) {
1465*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1466*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1467*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1468*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1469*4bdc9457SAndroid Build Coastguard Worker }
1470*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12,elements_div_12)1471*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12, elements_div_12) {
1472*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1473*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1474*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1475*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1476*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1477*4bdc9457SAndroid Build Coastguard Worker }
1478*4bdc9457SAndroid Build Coastguard Worker }
1479*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12,elements_lt_12)1480*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12, elements_lt_12) {
1481*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1482*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1483*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1484*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1485*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1486*4bdc9457SAndroid Build Coastguard Worker }
1487*4bdc9457SAndroid Build Coastguard Worker }
1488*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12,elements_gt_12)1489*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12, elements_gt_12) {
1490*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1491*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1492*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1493*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1494*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1495*4bdc9457SAndroid Build Coastguard Worker }
1496*4bdc9457SAndroid Build Coastguard Worker }
1497*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1498*4bdc9457SAndroid Build Coastguard Worker
1499*4bdc9457SAndroid Build Coastguard Worker
1500*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2,elements_eq_12)1501*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2, elements_eq_12) {
1502*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1503*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1504*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1505*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1506*4bdc9457SAndroid Build Coastguard Worker }
1507*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2,elements_div_12)1508*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2, elements_div_12) {
1509*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1510*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1511*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1512*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1513*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1514*4bdc9457SAndroid Build Coastguard Worker }
1515*4bdc9457SAndroid Build Coastguard Worker }
1516*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2,elements_lt_12)1517*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2, elements_lt_12) {
1518*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1519*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1520*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1521*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1522*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1523*4bdc9457SAndroid Build Coastguard Worker }
1524*4bdc9457SAndroid Build Coastguard Worker }
1525*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2,elements_gt_12)1526*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC2, elements_gt_12) {
1527*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1528*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1529*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1530*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1531*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1532*4bdc9457SAndroid Build Coastguard Worker }
1533*4bdc9457SAndroid Build Coastguard Worker }
1534*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1535*4bdc9457SAndroid Build Coastguard Worker
1536*4bdc9457SAndroid Build Coastguard Worker
1537*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3,elements_eq_12)1538*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3, elements_eq_12) {
1539*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1540*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1541*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1542*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1543*4bdc9457SAndroid Build Coastguard Worker }
1544*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3,elements_div_12)1545*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3, elements_div_12) {
1546*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1547*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1548*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1549*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1550*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1551*4bdc9457SAndroid Build Coastguard Worker }
1552*4bdc9457SAndroid Build Coastguard Worker }
1553*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3,elements_lt_12)1554*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3, elements_lt_12) {
1555*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1556*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1557*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1558*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1559*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1560*4bdc9457SAndroid Build Coastguard Worker }
1561*4bdc9457SAndroid Build Coastguard Worker }
1562*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3,elements_gt_12)1563*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X12_ACC3, elements_gt_12) {
1564*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1565*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1566*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1567*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1568*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x12_acc3, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1569*4bdc9457SAndroid Build Coastguard Worker }
1570*4bdc9457SAndroid Build Coastguard Worker }
1571*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1572*4bdc9457SAndroid Build Coastguard Worker
1573*4bdc9457SAndroid Build Coastguard Worker
1574*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16,elements_eq_16)1575*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16, elements_eq_16) {
1576*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1577*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1578*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1579*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1580*4bdc9457SAndroid Build Coastguard Worker }
1581*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16,elements_div_16)1582*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16, elements_div_16) {
1583*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1584*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1585*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1586*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1587*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1588*4bdc9457SAndroid Build Coastguard Worker }
1589*4bdc9457SAndroid Build Coastguard Worker }
1590*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16,elements_lt_16)1591*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16, elements_lt_16) {
1592*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1593*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1594*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1595*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1596*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1597*4bdc9457SAndroid Build Coastguard Worker }
1598*4bdc9457SAndroid Build Coastguard Worker }
1599*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16,elements_gt_16)1600*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16, elements_gt_16) {
1601*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1602*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1603*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1604*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1605*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1606*4bdc9457SAndroid Build Coastguard Worker }
1607*4bdc9457SAndroid Build Coastguard Worker }
1608*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1609*4bdc9457SAndroid Build Coastguard Worker
1610*4bdc9457SAndroid Build Coastguard Worker
1611*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2,elements_eq_16)1612*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2, elements_eq_16) {
1613*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1614*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1615*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1616*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1617*4bdc9457SAndroid Build Coastguard Worker }
1618*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2,elements_div_16)1619*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2, elements_div_16) {
1620*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1621*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1622*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1623*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1624*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1625*4bdc9457SAndroid Build Coastguard Worker }
1626*4bdc9457SAndroid Build Coastguard Worker }
1627*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2,elements_lt_16)1628*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2, elements_lt_16) {
1629*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1630*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1631*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1632*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1633*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1634*4bdc9457SAndroid Build Coastguard Worker }
1635*4bdc9457SAndroid Build Coastguard Worker }
1636*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2,elements_gt_16)1637*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC2, elements_gt_16) {
1638*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1639*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1640*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1641*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1642*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1643*4bdc9457SAndroid Build Coastguard Worker }
1644*4bdc9457SAndroid Build Coastguard Worker }
1645*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1646*4bdc9457SAndroid Build Coastguard Worker
1647*4bdc9457SAndroid Build Coastguard Worker
1648*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4,elements_eq_16)1649*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4, elements_eq_16) {
1650*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1651*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1652*4bdc9457SAndroid Build Coastguard Worker .elements(16)
1653*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1654*4bdc9457SAndroid Build Coastguard Worker }
1655*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4,elements_div_16)1656*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4, elements_div_16) {
1657*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1658*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
1659*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1660*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1661*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1662*4bdc9457SAndroid Build Coastguard Worker }
1663*4bdc9457SAndroid Build Coastguard Worker }
1664*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4,elements_lt_16)1665*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4, elements_lt_16) {
1666*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1667*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
1668*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1669*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1670*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1671*4bdc9457SAndroid Build Coastguard Worker }
1672*4bdc9457SAndroid Build Coastguard Worker }
1673*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4,elements_gt_16)1674*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X16_ACC4, elements_gt_16) {
1675*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1676*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
1677*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1678*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1679*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x16_acc4, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1680*4bdc9457SAndroid Build Coastguard Worker }
1681*4bdc9457SAndroid Build Coastguard Worker }
1682*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1683*4bdc9457SAndroid Build Coastguard Worker
1684*4bdc9457SAndroid Build Coastguard Worker
1685*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20,elements_eq_20)1686*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20, elements_eq_20) {
1687*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1688*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1689*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1690*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1691*4bdc9457SAndroid Build Coastguard Worker }
1692*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20,elements_div_20)1693*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20, elements_div_20) {
1694*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1695*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1696*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1697*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1699*4bdc9457SAndroid Build Coastguard Worker }
1700*4bdc9457SAndroid Build Coastguard Worker }
1701*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20,elements_lt_20)1702*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20, elements_lt_20) {
1703*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1704*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1705*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1706*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1707*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1708*4bdc9457SAndroid Build Coastguard Worker }
1709*4bdc9457SAndroid Build Coastguard Worker }
1710*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20,elements_gt_20)1711*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20, elements_gt_20) {
1712*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1713*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1714*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1715*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1716*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1717*4bdc9457SAndroid Build Coastguard Worker }
1718*4bdc9457SAndroid Build Coastguard Worker }
1719*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1720*4bdc9457SAndroid Build Coastguard Worker
1721*4bdc9457SAndroid Build Coastguard Worker
1722*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2,elements_eq_20)1723*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2, elements_eq_20) {
1724*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1725*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1726*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1727*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1728*4bdc9457SAndroid Build Coastguard Worker }
1729*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2,elements_div_20)1730*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2, elements_div_20) {
1731*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1732*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1733*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1734*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1735*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1736*4bdc9457SAndroid Build Coastguard Worker }
1737*4bdc9457SAndroid Build Coastguard Worker }
1738*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2,elements_lt_20)1739*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2, elements_lt_20) {
1740*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1741*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1742*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1743*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1744*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1745*4bdc9457SAndroid Build Coastguard Worker }
1746*4bdc9457SAndroid Build Coastguard Worker }
1747*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2,elements_gt_20)1748*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC2, elements_gt_20) {
1749*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1750*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1751*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1752*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1753*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc2, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1754*4bdc9457SAndroid Build Coastguard Worker }
1755*4bdc9457SAndroid Build Coastguard Worker }
1756*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1757*4bdc9457SAndroid Build Coastguard Worker
1758*4bdc9457SAndroid Build Coastguard Worker
1759*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_ARM || XNN_ARCH_ARM64
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5,elements_eq_20)1760*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5, elements_eq_20) {
1761*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1762*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1763*4bdc9457SAndroid Build Coastguard Worker .elements(20)
1764*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1765*4bdc9457SAndroid Build Coastguard Worker }
1766*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5,elements_div_20)1767*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5, elements_div_20) {
1768*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1769*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
1770*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1771*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1772*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1773*4bdc9457SAndroid Build Coastguard Worker }
1774*4bdc9457SAndroid Build Coastguard Worker }
1775*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5,elements_lt_20)1776*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5, elements_lt_20) {
1777*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1778*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
1779*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1780*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1781*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1782*4bdc9457SAndroid Build Coastguard Worker }
1783*4bdc9457SAndroid Build Coastguard Worker }
1784*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5,elements_gt_20)1785*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__NEONFMA_RR1_P5_X20_ACC5, elements_gt_20) {
1786*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_ARM_NEON_FMA;
1787*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
1788*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1789*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1790*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__neonfma_rr1_p5_x20_acc5, xnn_init_f32_expminus_neonfma_rr1_p5_params);
1791*4bdc9457SAndroid Build Coastguard Worker }
1792*4bdc9457SAndroid Build Coastguard Worker }
1793*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_ARM || XNN_ARCH_ARM64
1794*4bdc9457SAndroid Build Coastguard Worker
1795*4bdc9457SAndroid Build Coastguard Worker
1796*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4,elements_eq_4)1797*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4, elements_eq_4) {
1798*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1799*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1800*4bdc9457SAndroid Build Coastguard Worker .elements(4)
1801*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x4, xnn_init_f32_expminus_sse2_rr2_p5_params);
1802*4bdc9457SAndroid Build Coastguard Worker }
1803*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4,elements_div_4)1804*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4, elements_div_4) {
1805*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1806*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
1807*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1808*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1809*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x4, xnn_init_f32_expminus_sse2_rr2_p5_params);
1810*4bdc9457SAndroid Build Coastguard Worker }
1811*4bdc9457SAndroid Build Coastguard Worker }
1812*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4,elements_lt_4)1813*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4, elements_lt_4) {
1814*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1815*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
1816*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1817*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1818*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x4, xnn_init_f32_expminus_sse2_rr2_p5_params);
1819*4bdc9457SAndroid Build Coastguard Worker }
1820*4bdc9457SAndroid Build Coastguard Worker }
1821*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4,elements_gt_4)1822*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X4, elements_gt_4) {
1823*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1824*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
1825*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1826*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1827*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x4, xnn_init_f32_expminus_sse2_rr2_p5_params);
1828*4bdc9457SAndroid Build Coastguard Worker }
1829*4bdc9457SAndroid Build Coastguard Worker }
1830*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1831*4bdc9457SAndroid Build Coastguard Worker
1832*4bdc9457SAndroid Build Coastguard Worker
1833*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8,elements_eq_8)1834*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8, elements_eq_8) {
1835*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1836*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1837*4bdc9457SAndroid Build Coastguard Worker .elements(8)
1838*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8, xnn_init_f32_expminus_sse2_rr2_p5_params);
1839*4bdc9457SAndroid Build Coastguard Worker }
1840*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8,elements_div_8)1841*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8, elements_div_8) {
1842*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1843*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
1844*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1845*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1846*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8, xnn_init_f32_expminus_sse2_rr2_p5_params);
1847*4bdc9457SAndroid Build Coastguard Worker }
1848*4bdc9457SAndroid Build Coastguard Worker }
1849*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8,elements_lt_8)1850*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8, elements_lt_8) {
1851*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1852*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
1853*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1854*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1855*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8, xnn_init_f32_expminus_sse2_rr2_p5_params);
1856*4bdc9457SAndroid Build Coastguard Worker }
1857*4bdc9457SAndroid Build Coastguard Worker }
1858*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8,elements_gt_8)1859*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8, elements_gt_8) {
1860*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1861*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
1862*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1863*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1864*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8, xnn_init_f32_expminus_sse2_rr2_p5_params);
1865*4bdc9457SAndroid Build Coastguard Worker }
1866*4bdc9457SAndroid Build Coastguard Worker }
1867*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1868*4bdc9457SAndroid Build Coastguard Worker
1869*4bdc9457SAndroid Build Coastguard Worker
1870*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2,elements_eq_8)1871*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2, elements_eq_8) {
1872*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1873*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1874*4bdc9457SAndroid Build Coastguard Worker .elements(8)
1875*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1876*4bdc9457SAndroid Build Coastguard Worker }
1877*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2,elements_div_8)1878*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2, elements_div_8) {
1879*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1880*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
1881*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1882*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1883*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1884*4bdc9457SAndroid Build Coastguard Worker }
1885*4bdc9457SAndroid Build Coastguard Worker }
1886*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2,elements_lt_8)1887*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2, elements_lt_8) {
1888*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1889*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
1890*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1891*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1892*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1893*4bdc9457SAndroid Build Coastguard Worker }
1894*4bdc9457SAndroid Build Coastguard Worker }
1895*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2,elements_gt_8)1896*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X8_ACC2, elements_gt_8) {
1897*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1898*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
1899*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1900*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1901*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x8_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1902*4bdc9457SAndroid Build Coastguard Worker }
1903*4bdc9457SAndroid Build Coastguard Worker }
1904*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1905*4bdc9457SAndroid Build Coastguard Worker
1906*4bdc9457SAndroid Build Coastguard Worker
1907*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12,elements_eq_12)1908*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12, elements_eq_12) {
1909*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1910*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1911*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1912*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12, xnn_init_f32_expminus_sse2_rr2_p5_params);
1913*4bdc9457SAndroid Build Coastguard Worker }
1914*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12,elements_div_12)1915*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12, elements_div_12) {
1916*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1917*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1918*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1919*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1920*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12, xnn_init_f32_expminus_sse2_rr2_p5_params);
1921*4bdc9457SAndroid Build Coastguard Worker }
1922*4bdc9457SAndroid Build Coastguard Worker }
1923*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12,elements_lt_12)1924*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12, elements_lt_12) {
1925*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1926*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1927*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1928*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1929*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12, xnn_init_f32_expminus_sse2_rr2_p5_params);
1930*4bdc9457SAndroid Build Coastguard Worker }
1931*4bdc9457SAndroid Build Coastguard Worker }
1932*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12,elements_gt_12)1933*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12, elements_gt_12) {
1934*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1935*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1936*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1937*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1938*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12, xnn_init_f32_expminus_sse2_rr2_p5_params);
1939*4bdc9457SAndroid Build Coastguard Worker }
1940*4bdc9457SAndroid Build Coastguard Worker }
1941*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1942*4bdc9457SAndroid Build Coastguard Worker
1943*4bdc9457SAndroid Build Coastguard Worker
1944*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2,elements_eq_12)1945*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2, elements_eq_12) {
1946*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1947*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1948*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1949*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1950*4bdc9457SAndroid Build Coastguard Worker }
1951*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2,elements_div_12)1952*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2, elements_div_12) {
1953*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1954*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1955*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1956*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1957*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1958*4bdc9457SAndroid Build Coastguard Worker }
1959*4bdc9457SAndroid Build Coastguard Worker }
1960*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2,elements_lt_12)1961*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2, elements_lt_12) {
1962*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1963*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
1964*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1965*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1966*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1967*4bdc9457SAndroid Build Coastguard Worker }
1968*4bdc9457SAndroid Build Coastguard Worker }
1969*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2,elements_gt_12)1970*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC2, elements_gt_12) {
1971*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1972*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
1973*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1974*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1975*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
1976*4bdc9457SAndroid Build Coastguard Worker }
1977*4bdc9457SAndroid Build Coastguard Worker }
1978*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
1979*4bdc9457SAndroid Build Coastguard Worker
1980*4bdc9457SAndroid Build Coastguard Worker
1981*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3,elements_eq_12)1982*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3, elements_eq_12) {
1983*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1984*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1985*4bdc9457SAndroid Build Coastguard Worker .elements(12)
1986*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc3, xnn_init_f32_expminus_sse2_rr2_p5_params);
1987*4bdc9457SAndroid Build Coastguard Worker }
1988*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3,elements_div_12)1989*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3, elements_div_12) {
1990*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
1991*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
1992*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
1993*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
1994*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc3, xnn_init_f32_expminus_sse2_rr2_p5_params);
1995*4bdc9457SAndroid Build Coastguard Worker }
1996*4bdc9457SAndroid Build Coastguard Worker }
1997*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3,elements_lt_12)1998*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3, elements_lt_12) {
1999*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2000*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
2001*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2002*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2003*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc3, xnn_init_f32_expminus_sse2_rr2_p5_params);
2004*4bdc9457SAndroid Build Coastguard Worker }
2005*4bdc9457SAndroid Build Coastguard Worker }
2006*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3,elements_gt_12)2007*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X12_ACC3, elements_gt_12) {
2008*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2009*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
2010*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2011*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2012*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x12_acc3, xnn_init_f32_expminus_sse2_rr2_p5_params);
2013*4bdc9457SAndroid Build Coastguard Worker }
2014*4bdc9457SAndroid Build Coastguard Worker }
2015*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2016*4bdc9457SAndroid Build Coastguard Worker
2017*4bdc9457SAndroid Build Coastguard Worker
2018*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16,elements_eq_16)2019*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16, elements_eq_16) {
2020*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2021*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2022*4bdc9457SAndroid Build Coastguard Worker .elements(16)
2023*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16, xnn_init_f32_expminus_sse2_rr2_p5_params);
2024*4bdc9457SAndroid Build Coastguard Worker }
2025*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16,elements_div_16)2026*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16, elements_div_16) {
2027*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2028*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
2029*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2030*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2031*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16, xnn_init_f32_expminus_sse2_rr2_p5_params);
2032*4bdc9457SAndroid Build Coastguard Worker }
2033*4bdc9457SAndroid Build Coastguard Worker }
2034*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16,elements_lt_16)2035*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16, elements_lt_16) {
2036*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2037*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
2038*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2039*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2040*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16, xnn_init_f32_expminus_sse2_rr2_p5_params);
2041*4bdc9457SAndroid Build Coastguard Worker }
2042*4bdc9457SAndroid Build Coastguard Worker }
2043*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16,elements_gt_16)2044*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16, elements_gt_16) {
2045*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2046*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
2047*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2048*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2049*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16, xnn_init_f32_expminus_sse2_rr2_p5_params);
2050*4bdc9457SAndroid Build Coastguard Worker }
2051*4bdc9457SAndroid Build Coastguard Worker }
2052*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2053*4bdc9457SAndroid Build Coastguard Worker
2054*4bdc9457SAndroid Build Coastguard Worker
2055*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2,elements_eq_16)2056*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2, elements_eq_16) {
2057*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2058*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2059*4bdc9457SAndroid Build Coastguard Worker .elements(16)
2060*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2061*4bdc9457SAndroid Build Coastguard Worker }
2062*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2,elements_div_16)2063*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2, elements_div_16) {
2064*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2065*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
2066*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2067*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2068*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2069*4bdc9457SAndroid Build Coastguard Worker }
2070*4bdc9457SAndroid Build Coastguard Worker }
2071*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2,elements_lt_16)2072*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2, elements_lt_16) {
2073*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2074*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
2075*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2076*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2077*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2078*4bdc9457SAndroid Build Coastguard Worker }
2079*4bdc9457SAndroid Build Coastguard Worker }
2080*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2,elements_gt_16)2081*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC2, elements_gt_16) {
2082*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2083*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
2084*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2085*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2086*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2087*4bdc9457SAndroid Build Coastguard Worker }
2088*4bdc9457SAndroid Build Coastguard Worker }
2089*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2090*4bdc9457SAndroid Build Coastguard Worker
2091*4bdc9457SAndroid Build Coastguard Worker
2092*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4,elements_eq_16)2093*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4, elements_eq_16) {
2094*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2095*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2096*4bdc9457SAndroid Build Coastguard Worker .elements(16)
2097*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc4, xnn_init_f32_expminus_sse2_rr2_p5_params);
2098*4bdc9457SAndroid Build Coastguard Worker }
2099*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4,elements_div_16)2100*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4, elements_div_16) {
2101*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2102*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
2103*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2104*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2105*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc4, xnn_init_f32_expminus_sse2_rr2_p5_params);
2106*4bdc9457SAndroid Build Coastguard Worker }
2107*4bdc9457SAndroid Build Coastguard Worker }
2108*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4,elements_lt_16)2109*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4, elements_lt_16) {
2110*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2111*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
2112*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2113*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2114*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc4, xnn_init_f32_expminus_sse2_rr2_p5_params);
2115*4bdc9457SAndroid Build Coastguard Worker }
2116*4bdc9457SAndroid Build Coastguard Worker }
2117*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4,elements_gt_16)2118*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X16_ACC4, elements_gt_16) {
2119*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2120*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
2121*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2122*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2123*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x16_acc4, xnn_init_f32_expminus_sse2_rr2_p5_params);
2124*4bdc9457SAndroid Build Coastguard Worker }
2125*4bdc9457SAndroid Build Coastguard Worker }
2126*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2127*4bdc9457SAndroid Build Coastguard Worker
2128*4bdc9457SAndroid Build Coastguard Worker
2129*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20,elements_eq_20)2130*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20, elements_eq_20) {
2131*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2132*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2133*4bdc9457SAndroid Build Coastguard Worker .elements(20)
2134*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20, xnn_init_f32_expminus_sse2_rr2_p5_params);
2135*4bdc9457SAndroid Build Coastguard Worker }
2136*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20,elements_div_20)2137*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20, elements_div_20) {
2138*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2139*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
2140*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2141*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2142*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20, xnn_init_f32_expminus_sse2_rr2_p5_params);
2143*4bdc9457SAndroid Build Coastguard Worker }
2144*4bdc9457SAndroid Build Coastguard Worker }
2145*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20,elements_lt_20)2146*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20, elements_lt_20) {
2147*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2148*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
2149*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2150*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2151*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20, xnn_init_f32_expminus_sse2_rr2_p5_params);
2152*4bdc9457SAndroid Build Coastguard Worker }
2153*4bdc9457SAndroid Build Coastguard Worker }
2154*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20,elements_gt_20)2155*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20, elements_gt_20) {
2156*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2157*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
2158*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2159*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2160*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20, xnn_init_f32_expminus_sse2_rr2_p5_params);
2161*4bdc9457SAndroid Build Coastguard Worker }
2162*4bdc9457SAndroid Build Coastguard Worker }
2163*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2164*4bdc9457SAndroid Build Coastguard Worker
2165*4bdc9457SAndroid Build Coastguard Worker
2166*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2,elements_eq_20)2167*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2, elements_eq_20) {
2168*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2169*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2170*4bdc9457SAndroid Build Coastguard Worker .elements(20)
2171*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2172*4bdc9457SAndroid Build Coastguard Worker }
2173*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2,elements_div_20)2174*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2, elements_div_20) {
2175*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2176*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
2177*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2178*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2179*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2180*4bdc9457SAndroid Build Coastguard Worker }
2181*4bdc9457SAndroid Build Coastguard Worker }
2182*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2,elements_lt_20)2183*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2, elements_lt_20) {
2184*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2185*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
2186*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2187*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2188*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2189*4bdc9457SAndroid Build Coastguard Worker }
2190*4bdc9457SAndroid Build Coastguard Worker }
2191*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2,elements_gt_20)2192*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC2, elements_gt_20) {
2193*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2194*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
2195*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2196*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2197*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc2, xnn_init_f32_expminus_sse2_rr2_p5_params);
2198*4bdc9457SAndroid Build Coastguard Worker }
2199*4bdc9457SAndroid Build Coastguard Worker }
2200*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2201*4bdc9457SAndroid Build Coastguard Worker
2202*4bdc9457SAndroid Build Coastguard Worker
2203*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5,elements_eq_20)2204*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5, elements_eq_20) {
2205*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2206*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2207*4bdc9457SAndroid Build Coastguard Worker .elements(20)
2208*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc5, xnn_init_f32_expminus_sse2_rr2_p5_params);
2209*4bdc9457SAndroid Build Coastguard Worker }
2210*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5,elements_div_20)2211*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5, elements_div_20) {
2212*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2213*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
2214*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2215*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2216*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc5, xnn_init_f32_expminus_sse2_rr2_p5_params);
2217*4bdc9457SAndroid Build Coastguard Worker }
2218*4bdc9457SAndroid Build Coastguard Worker }
2219*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5,elements_lt_20)2220*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5, elements_lt_20) {
2221*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2222*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
2223*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2224*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2225*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc5, xnn_init_f32_expminus_sse2_rr2_p5_params);
2226*4bdc9457SAndroid Build Coastguard Worker }
2227*4bdc9457SAndroid Build Coastguard Worker }
2228*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5,elements_gt_20)2229*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SSE2_RR2_P5_X20_ACC5, elements_gt_20) {
2230*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_SSE2;
2231*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
2232*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2233*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2234*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__sse2_rr2_p5_x20_acc5, xnn_init_f32_expminus_sse2_rr2_p5_params);
2235*4bdc9457SAndroid Build Coastguard Worker }
2236*4bdc9457SAndroid Build Coastguard Worker }
2237*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2238*4bdc9457SAndroid Build Coastguard Worker
2239*4bdc9457SAndroid Build Coastguard Worker
2240*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64,elements_eq_64)2241*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64, elements_eq_64) {
2242*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2243*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2244*4bdc9457SAndroid Build Coastguard Worker .elements(64)
2245*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64, xnn_init_f32_expminus_avx2_rr1_p5_params);
2246*4bdc9457SAndroid Build Coastguard Worker }
2247*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64,elements_div_64)2248*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64, elements_div_64) {
2249*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2250*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 128; elements < 640; elements += 64) {
2251*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2252*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2253*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64, xnn_init_f32_expminus_avx2_rr1_p5_params);
2254*4bdc9457SAndroid Build Coastguard Worker }
2255*4bdc9457SAndroid Build Coastguard Worker }
2256*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64,elements_lt_64)2257*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64, elements_lt_64) {
2258*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2259*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 64; elements++) {
2260*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2261*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2262*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64, xnn_init_f32_expminus_avx2_rr1_p5_params);
2263*4bdc9457SAndroid Build Coastguard Worker }
2264*4bdc9457SAndroid Build Coastguard Worker }
2265*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64,elements_gt_64)2266*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64, elements_gt_64) {
2267*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2268*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 65; elements < 128; elements++) {
2269*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2270*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64, xnn_init_f32_expminus_avx2_rr1_p5_params);
2272*4bdc9457SAndroid Build Coastguard Worker }
2273*4bdc9457SAndroid Build Coastguard Worker }
2274*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2275*4bdc9457SAndroid Build Coastguard Worker
2276*4bdc9457SAndroid Build Coastguard Worker
2277*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2,elements_eq_64)2278*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2, elements_eq_64) {
2279*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2280*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2281*4bdc9457SAndroid Build Coastguard Worker .elements(64)
2282*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2283*4bdc9457SAndroid Build Coastguard Worker }
2284*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2,elements_div_64)2285*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2, elements_div_64) {
2286*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2287*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 128; elements < 640; elements += 64) {
2288*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2289*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2290*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2291*4bdc9457SAndroid Build Coastguard Worker }
2292*4bdc9457SAndroid Build Coastguard Worker }
2293*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2,elements_lt_64)2294*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2, elements_lt_64) {
2295*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2296*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 64; elements++) {
2297*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2298*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2299*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2300*4bdc9457SAndroid Build Coastguard Worker }
2301*4bdc9457SAndroid Build Coastguard Worker }
2302*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2,elements_gt_64)2303*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC2, elements_gt_64) {
2304*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2305*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 65; elements < 128; elements++) {
2306*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2307*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2308*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2309*4bdc9457SAndroid Build Coastguard Worker }
2310*4bdc9457SAndroid Build Coastguard Worker }
2311*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2312*4bdc9457SAndroid Build Coastguard Worker
2313*4bdc9457SAndroid Build Coastguard Worker
2314*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4,elements_eq_64)2315*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4, elements_eq_64) {
2316*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2317*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2318*4bdc9457SAndroid Build Coastguard Worker .elements(64)
2319*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc4, xnn_init_f32_expminus_avx2_rr1_p5_params);
2320*4bdc9457SAndroid Build Coastguard Worker }
2321*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4,elements_div_64)2322*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4, elements_div_64) {
2323*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2324*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 128; elements < 640; elements += 64) {
2325*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2326*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2327*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc4, xnn_init_f32_expminus_avx2_rr1_p5_params);
2328*4bdc9457SAndroid Build Coastguard Worker }
2329*4bdc9457SAndroid Build Coastguard Worker }
2330*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4,elements_lt_64)2331*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4, elements_lt_64) {
2332*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2333*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 64; elements++) {
2334*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2335*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2336*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc4, xnn_init_f32_expminus_avx2_rr1_p5_params);
2337*4bdc9457SAndroid Build Coastguard Worker }
2338*4bdc9457SAndroid Build Coastguard Worker }
2339*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4,elements_gt_64)2340*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X64_ACC4, elements_gt_64) {
2341*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2342*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 65; elements < 128; elements++) {
2343*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2344*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2345*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x64_acc4, xnn_init_f32_expminus_avx2_rr1_p5_params);
2346*4bdc9457SAndroid Build Coastguard Worker }
2347*4bdc9457SAndroid Build Coastguard Worker }
2348*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2349*4bdc9457SAndroid Build Coastguard Worker
2350*4bdc9457SAndroid Build Coastguard Worker
2351*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72,elements_eq_72)2352*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72, elements_eq_72) {
2353*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2354*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2355*4bdc9457SAndroid Build Coastguard Worker .elements(72)
2356*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72, xnn_init_f32_expminus_avx2_rr1_p5_params);
2357*4bdc9457SAndroid Build Coastguard Worker }
2358*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72,elements_div_72)2359*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72, elements_div_72) {
2360*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2361*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 144; elements < 720; elements += 72) {
2362*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2363*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2364*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72, xnn_init_f32_expminus_avx2_rr1_p5_params);
2365*4bdc9457SAndroid Build Coastguard Worker }
2366*4bdc9457SAndroid Build Coastguard Worker }
2367*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72,elements_lt_72)2368*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72, elements_lt_72) {
2369*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2370*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 72; elements++) {
2371*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2372*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2373*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72, xnn_init_f32_expminus_avx2_rr1_p5_params);
2374*4bdc9457SAndroid Build Coastguard Worker }
2375*4bdc9457SAndroid Build Coastguard Worker }
2376*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72,elements_gt_72)2377*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72, elements_gt_72) {
2378*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2379*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 73; elements < 144; elements++) {
2380*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2381*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2382*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72, xnn_init_f32_expminus_avx2_rr1_p5_params);
2383*4bdc9457SAndroid Build Coastguard Worker }
2384*4bdc9457SAndroid Build Coastguard Worker }
2385*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2386*4bdc9457SAndroid Build Coastguard Worker
2387*4bdc9457SAndroid Build Coastguard Worker
2388*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3,elements_eq_72)2389*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3, elements_eq_72) {
2390*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2391*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2392*4bdc9457SAndroid Build Coastguard Worker .elements(72)
2393*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2394*4bdc9457SAndroid Build Coastguard Worker }
2395*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3,elements_div_72)2396*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3, elements_div_72) {
2397*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2398*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 144; elements < 720; elements += 72) {
2399*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2400*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2401*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2402*4bdc9457SAndroid Build Coastguard Worker }
2403*4bdc9457SAndroid Build Coastguard Worker }
2404*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3,elements_lt_72)2405*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3, elements_lt_72) {
2406*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2407*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 72; elements++) {
2408*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2409*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2410*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2411*4bdc9457SAndroid Build Coastguard Worker }
2412*4bdc9457SAndroid Build Coastguard Worker }
2413*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3,elements_gt_72)2414*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X72_ACC3, elements_gt_72) {
2415*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2416*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 73; elements < 144; elements++) {
2417*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2418*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2419*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x72_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2420*4bdc9457SAndroid Build Coastguard Worker }
2421*4bdc9457SAndroid Build Coastguard Worker }
2422*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2423*4bdc9457SAndroid Build Coastguard Worker
2424*4bdc9457SAndroid Build Coastguard Worker
2425*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80,elements_eq_80)2426*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80, elements_eq_80) {
2427*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2428*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2429*4bdc9457SAndroid Build Coastguard Worker .elements(80)
2430*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80, xnn_init_f32_expminus_avx2_rr1_p5_params);
2431*4bdc9457SAndroid Build Coastguard Worker }
2432*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80,elements_div_80)2433*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80, elements_div_80) {
2434*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2435*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 160; elements < 800; elements += 80) {
2436*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2437*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2438*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80, xnn_init_f32_expminus_avx2_rr1_p5_params);
2439*4bdc9457SAndroid Build Coastguard Worker }
2440*4bdc9457SAndroid Build Coastguard Worker }
2441*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80,elements_lt_80)2442*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80, elements_lt_80) {
2443*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2444*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 80; elements++) {
2445*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2446*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2447*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80, xnn_init_f32_expminus_avx2_rr1_p5_params);
2448*4bdc9457SAndroid Build Coastguard Worker }
2449*4bdc9457SAndroid Build Coastguard Worker }
2450*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80,elements_gt_80)2451*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80, elements_gt_80) {
2452*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2453*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 81; elements < 160; elements++) {
2454*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2455*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2456*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80, xnn_init_f32_expminus_avx2_rr1_p5_params);
2457*4bdc9457SAndroid Build Coastguard Worker }
2458*4bdc9457SAndroid Build Coastguard Worker }
2459*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2460*4bdc9457SAndroid Build Coastguard Worker
2461*4bdc9457SAndroid Build Coastguard Worker
2462*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2,elements_eq_80)2463*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2, elements_eq_80) {
2464*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2465*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2466*4bdc9457SAndroid Build Coastguard Worker .elements(80)
2467*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2468*4bdc9457SAndroid Build Coastguard Worker }
2469*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2,elements_div_80)2470*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2, elements_div_80) {
2471*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2472*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 160; elements < 800; elements += 80) {
2473*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2474*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2475*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2476*4bdc9457SAndroid Build Coastguard Worker }
2477*4bdc9457SAndroid Build Coastguard Worker }
2478*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2,elements_lt_80)2479*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2, elements_lt_80) {
2480*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2481*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 80; elements++) {
2482*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2483*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2484*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2485*4bdc9457SAndroid Build Coastguard Worker }
2486*4bdc9457SAndroid Build Coastguard Worker }
2487*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2,elements_gt_80)2488*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC2, elements_gt_80) {
2489*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2490*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 81; elements < 160; elements++) {
2491*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2492*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2493*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2494*4bdc9457SAndroid Build Coastguard Worker }
2495*4bdc9457SAndroid Build Coastguard Worker }
2496*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2497*4bdc9457SAndroid Build Coastguard Worker
2498*4bdc9457SAndroid Build Coastguard Worker
2499*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5,elements_eq_80)2500*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5, elements_eq_80) {
2501*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2502*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2503*4bdc9457SAndroid Build Coastguard Worker .elements(80)
2504*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc5, xnn_init_f32_expminus_avx2_rr1_p5_params);
2505*4bdc9457SAndroid Build Coastguard Worker }
2506*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5,elements_div_80)2507*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5, elements_div_80) {
2508*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2509*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 160; elements < 800; elements += 80) {
2510*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2511*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2512*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc5, xnn_init_f32_expminus_avx2_rr1_p5_params);
2513*4bdc9457SAndroid Build Coastguard Worker }
2514*4bdc9457SAndroid Build Coastguard Worker }
2515*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5,elements_lt_80)2516*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5, elements_lt_80) {
2517*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2518*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 80; elements++) {
2519*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2520*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2521*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc5, xnn_init_f32_expminus_avx2_rr1_p5_params);
2522*4bdc9457SAndroid Build Coastguard Worker }
2523*4bdc9457SAndroid Build Coastguard Worker }
2524*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5,elements_gt_80)2525*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X80_ACC5, elements_gt_80) {
2526*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2527*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 81; elements < 160; elements++) {
2528*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2529*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2530*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x80_acc5, xnn_init_f32_expminus_avx2_rr1_p5_params);
2531*4bdc9457SAndroid Build Coastguard Worker }
2532*4bdc9457SAndroid Build Coastguard Worker }
2533*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2534*4bdc9457SAndroid Build Coastguard Worker
2535*4bdc9457SAndroid Build Coastguard Worker
2536*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96,elements_eq_96)2537*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96, elements_eq_96) {
2538*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2539*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2540*4bdc9457SAndroid Build Coastguard Worker .elements(96)
2541*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96, xnn_init_f32_expminus_avx2_rr1_p5_params);
2542*4bdc9457SAndroid Build Coastguard Worker }
2543*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96,elements_div_96)2544*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96, elements_div_96) {
2545*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2546*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 192; elements < 960; elements += 96) {
2547*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2548*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2549*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96, xnn_init_f32_expminus_avx2_rr1_p5_params);
2550*4bdc9457SAndroid Build Coastguard Worker }
2551*4bdc9457SAndroid Build Coastguard Worker }
2552*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96,elements_lt_96)2553*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96, elements_lt_96) {
2554*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2555*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 96; elements++) {
2556*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2557*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2558*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96, xnn_init_f32_expminus_avx2_rr1_p5_params);
2559*4bdc9457SAndroid Build Coastguard Worker }
2560*4bdc9457SAndroid Build Coastguard Worker }
2561*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96,elements_gt_96)2562*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96, elements_gt_96) {
2563*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2564*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 97; elements < 192; elements++) {
2565*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2566*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2567*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96, xnn_init_f32_expminus_avx2_rr1_p5_params);
2568*4bdc9457SAndroid Build Coastguard Worker }
2569*4bdc9457SAndroid Build Coastguard Worker }
2570*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2571*4bdc9457SAndroid Build Coastguard Worker
2572*4bdc9457SAndroid Build Coastguard Worker
2573*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2,elements_eq_96)2574*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2, elements_eq_96) {
2575*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2576*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2577*4bdc9457SAndroid Build Coastguard Worker .elements(96)
2578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2579*4bdc9457SAndroid Build Coastguard Worker }
2580*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2,elements_div_96)2581*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2, elements_div_96) {
2582*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2583*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 192; elements < 960; elements += 96) {
2584*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2585*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2586*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2587*4bdc9457SAndroid Build Coastguard Worker }
2588*4bdc9457SAndroid Build Coastguard Worker }
2589*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2,elements_lt_96)2590*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2, elements_lt_96) {
2591*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2592*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 96; elements++) {
2593*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2594*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2595*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2596*4bdc9457SAndroid Build Coastguard Worker }
2597*4bdc9457SAndroid Build Coastguard Worker }
2598*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2,elements_gt_96)2599*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC2, elements_gt_96) {
2600*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2601*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 97; elements < 192; elements++) {
2602*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2603*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2604*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc2, xnn_init_f32_expminus_avx2_rr1_p5_params);
2605*4bdc9457SAndroid Build Coastguard Worker }
2606*4bdc9457SAndroid Build Coastguard Worker }
2607*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2608*4bdc9457SAndroid Build Coastguard Worker
2609*4bdc9457SAndroid Build Coastguard Worker
2610*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3,elements_eq_96)2611*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3, elements_eq_96) {
2612*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2613*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2614*4bdc9457SAndroid Build Coastguard Worker .elements(96)
2615*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2616*4bdc9457SAndroid Build Coastguard Worker }
2617*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3,elements_div_96)2618*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3, elements_div_96) {
2619*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2620*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 192; elements < 960; elements += 96) {
2621*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2622*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2623*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2624*4bdc9457SAndroid Build Coastguard Worker }
2625*4bdc9457SAndroid Build Coastguard Worker }
2626*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3,elements_lt_96)2627*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3, elements_lt_96) {
2628*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2629*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 96; elements++) {
2630*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2631*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2632*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2633*4bdc9457SAndroid Build Coastguard Worker }
2634*4bdc9457SAndroid Build Coastguard Worker }
2635*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3,elements_gt_96)2636*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC3, elements_gt_96) {
2637*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2638*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 97; elements < 192; elements++) {
2639*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2640*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2641*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc3, xnn_init_f32_expminus_avx2_rr1_p5_params);
2642*4bdc9457SAndroid Build Coastguard Worker }
2643*4bdc9457SAndroid Build Coastguard Worker }
2644*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2645*4bdc9457SAndroid Build Coastguard Worker
2646*4bdc9457SAndroid Build Coastguard Worker
2647*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6,elements_eq_96)2648*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6, elements_eq_96) {
2649*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2650*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2651*4bdc9457SAndroid Build Coastguard Worker .elements(96)
2652*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc6, xnn_init_f32_expminus_avx2_rr1_p5_params);
2653*4bdc9457SAndroid Build Coastguard Worker }
2654*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6,elements_div_96)2655*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6, elements_div_96) {
2656*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2657*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 192; elements < 960; elements += 96) {
2658*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2659*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2660*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc6, xnn_init_f32_expminus_avx2_rr1_p5_params);
2661*4bdc9457SAndroid Build Coastguard Worker }
2662*4bdc9457SAndroid Build Coastguard Worker }
2663*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6,elements_lt_96)2664*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6, elements_lt_96) {
2665*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2666*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 96; elements++) {
2667*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2668*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2669*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc6, xnn_init_f32_expminus_avx2_rr1_p5_params);
2670*4bdc9457SAndroid Build Coastguard Worker }
2671*4bdc9457SAndroid Build Coastguard Worker }
2672*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6,elements_gt_96)2673*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX2_RR1_P5_X96_ACC6, elements_gt_96) {
2674*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX2;
2675*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 97; elements < 192; elements++) {
2676*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2677*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2678*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx2_rr1_p5_x96_acc6, xnn_init_f32_expminus_avx2_rr1_p5_params);
2679*4bdc9457SAndroid Build Coastguard Worker }
2680*4bdc9457SAndroid Build Coastguard Worker }
2681*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2682*4bdc9457SAndroid Build Coastguard Worker
2683*4bdc9457SAndroid Build Coastguard Worker
2684*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128,elements_eq_128)2685*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128, elements_eq_128) {
2686*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2687*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2688*4bdc9457SAndroid Build Coastguard Worker .elements(128)
2689*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128, xnn_init_f32_expminus_avx512_rr1_p5_params);
2690*4bdc9457SAndroid Build Coastguard Worker }
2691*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128,elements_div_128)2692*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128, elements_div_128) {
2693*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2694*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 256; elements < 1280; elements += 128) {
2695*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2696*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2697*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128, xnn_init_f32_expminus_avx512_rr1_p5_params);
2698*4bdc9457SAndroid Build Coastguard Worker }
2699*4bdc9457SAndroid Build Coastguard Worker }
2700*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128,elements_lt_128)2701*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128, elements_lt_128) {
2702*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2703*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 128; elements++) {
2704*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2705*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2706*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128, xnn_init_f32_expminus_avx512_rr1_p5_params);
2707*4bdc9457SAndroid Build Coastguard Worker }
2708*4bdc9457SAndroid Build Coastguard Worker }
2709*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128,elements_gt_128)2710*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128, elements_gt_128) {
2711*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2712*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 129; elements < 256; elements++) {
2713*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2714*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2715*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128, xnn_init_f32_expminus_avx512_rr1_p5_params);
2716*4bdc9457SAndroid Build Coastguard Worker }
2717*4bdc9457SAndroid Build Coastguard Worker }
2718*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2719*4bdc9457SAndroid Build Coastguard Worker
2720*4bdc9457SAndroid Build Coastguard Worker
2721*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2,elements_eq_128)2722*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2, elements_eq_128) {
2723*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2724*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2725*4bdc9457SAndroid Build Coastguard Worker .elements(128)
2726*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2727*4bdc9457SAndroid Build Coastguard Worker }
2728*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2,elements_div_128)2729*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2, elements_div_128) {
2730*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2731*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 256; elements < 1280; elements += 128) {
2732*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2733*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2734*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2735*4bdc9457SAndroid Build Coastguard Worker }
2736*4bdc9457SAndroid Build Coastguard Worker }
2737*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2,elements_lt_128)2738*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2, elements_lt_128) {
2739*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2740*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 128; elements++) {
2741*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2742*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2743*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2744*4bdc9457SAndroid Build Coastguard Worker }
2745*4bdc9457SAndroid Build Coastguard Worker }
2746*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2,elements_gt_128)2747*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC2, elements_gt_128) {
2748*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2749*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 129; elements < 256; elements++) {
2750*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2751*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2752*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2753*4bdc9457SAndroid Build Coastguard Worker }
2754*4bdc9457SAndroid Build Coastguard Worker }
2755*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2756*4bdc9457SAndroid Build Coastguard Worker
2757*4bdc9457SAndroid Build Coastguard Worker
2758*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4,elements_eq_128)2759*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4, elements_eq_128) {
2760*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2761*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2762*4bdc9457SAndroid Build Coastguard Worker .elements(128)
2763*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc4, xnn_init_f32_expminus_avx512_rr1_p5_params);
2764*4bdc9457SAndroid Build Coastguard Worker }
2765*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4,elements_div_128)2766*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4, elements_div_128) {
2767*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2768*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 256; elements < 1280; elements += 128) {
2769*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2770*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2771*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc4, xnn_init_f32_expminus_avx512_rr1_p5_params);
2772*4bdc9457SAndroid Build Coastguard Worker }
2773*4bdc9457SAndroid Build Coastguard Worker }
2774*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4,elements_lt_128)2775*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4, elements_lt_128) {
2776*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2777*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 128; elements++) {
2778*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2779*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2780*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc4, xnn_init_f32_expminus_avx512_rr1_p5_params);
2781*4bdc9457SAndroid Build Coastguard Worker }
2782*4bdc9457SAndroid Build Coastguard Worker }
2783*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4,elements_gt_128)2784*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X128_ACC4, elements_gt_128) {
2785*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2786*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 129; elements < 256; elements++) {
2787*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2788*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2789*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x128_acc4, xnn_init_f32_expminus_avx512_rr1_p5_params);
2790*4bdc9457SAndroid Build Coastguard Worker }
2791*4bdc9457SAndroid Build Coastguard Worker }
2792*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2793*4bdc9457SAndroid Build Coastguard Worker
2794*4bdc9457SAndroid Build Coastguard Worker
2795*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144,elements_eq_144)2796*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144, elements_eq_144) {
2797*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2798*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2799*4bdc9457SAndroid Build Coastguard Worker .elements(144)
2800*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144, xnn_init_f32_expminus_avx512_rr1_p5_params);
2801*4bdc9457SAndroid Build Coastguard Worker }
2802*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144,elements_div_144)2803*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144, elements_div_144) {
2804*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2805*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 288; elements < 1440; elements += 144) {
2806*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2807*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2808*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144, xnn_init_f32_expminus_avx512_rr1_p5_params);
2809*4bdc9457SAndroid Build Coastguard Worker }
2810*4bdc9457SAndroid Build Coastguard Worker }
2811*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144,elements_lt_144)2812*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144, elements_lt_144) {
2813*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2814*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 144; elements++) {
2815*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2816*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2817*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144, xnn_init_f32_expminus_avx512_rr1_p5_params);
2818*4bdc9457SAndroid Build Coastguard Worker }
2819*4bdc9457SAndroid Build Coastguard Worker }
2820*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144,elements_gt_144)2821*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144, elements_gt_144) {
2822*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2823*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 145; elements < 288; elements++) {
2824*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2825*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2826*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144, xnn_init_f32_expminus_avx512_rr1_p5_params);
2827*4bdc9457SAndroid Build Coastguard Worker }
2828*4bdc9457SAndroid Build Coastguard Worker }
2829*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2830*4bdc9457SAndroid Build Coastguard Worker
2831*4bdc9457SAndroid Build Coastguard Worker
2832*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3,elements_eq_144)2833*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3, elements_eq_144) {
2834*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2835*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2836*4bdc9457SAndroid Build Coastguard Worker .elements(144)
2837*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
2838*4bdc9457SAndroid Build Coastguard Worker }
2839*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3,elements_div_144)2840*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3, elements_div_144) {
2841*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2842*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 288; elements < 1440; elements += 144) {
2843*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2844*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2845*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
2846*4bdc9457SAndroid Build Coastguard Worker }
2847*4bdc9457SAndroid Build Coastguard Worker }
2848*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3,elements_lt_144)2849*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3, elements_lt_144) {
2850*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2851*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 144; elements++) {
2852*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2853*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2854*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
2855*4bdc9457SAndroid Build Coastguard Worker }
2856*4bdc9457SAndroid Build Coastguard Worker }
2857*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3,elements_gt_144)2858*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X144_ACC3, elements_gt_144) {
2859*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2860*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 145; elements < 288; elements++) {
2861*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2862*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2863*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x144_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
2864*4bdc9457SAndroid Build Coastguard Worker }
2865*4bdc9457SAndroid Build Coastguard Worker }
2866*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2867*4bdc9457SAndroid Build Coastguard Worker
2868*4bdc9457SAndroid Build Coastguard Worker
2869*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160,elements_eq_160)2870*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160, elements_eq_160) {
2871*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2872*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2873*4bdc9457SAndroid Build Coastguard Worker .elements(160)
2874*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160, xnn_init_f32_expminus_avx512_rr1_p5_params);
2875*4bdc9457SAndroid Build Coastguard Worker }
2876*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160,elements_div_160)2877*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160, elements_div_160) {
2878*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2879*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 320; elements < 1600; elements += 160) {
2880*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2881*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2882*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160, xnn_init_f32_expminus_avx512_rr1_p5_params);
2883*4bdc9457SAndroid Build Coastguard Worker }
2884*4bdc9457SAndroid Build Coastguard Worker }
2885*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160,elements_lt_160)2886*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160, elements_lt_160) {
2887*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2888*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 160; elements++) {
2889*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2890*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2891*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160, xnn_init_f32_expminus_avx512_rr1_p5_params);
2892*4bdc9457SAndroid Build Coastguard Worker }
2893*4bdc9457SAndroid Build Coastguard Worker }
2894*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160,elements_gt_160)2895*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160, elements_gt_160) {
2896*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2897*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 161; elements < 320; elements++) {
2898*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2899*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2900*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160, xnn_init_f32_expminus_avx512_rr1_p5_params);
2901*4bdc9457SAndroid Build Coastguard Worker }
2902*4bdc9457SAndroid Build Coastguard Worker }
2903*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2904*4bdc9457SAndroid Build Coastguard Worker
2905*4bdc9457SAndroid Build Coastguard Worker
2906*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2,elements_eq_160)2907*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2, elements_eq_160) {
2908*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2909*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2910*4bdc9457SAndroid Build Coastguard Worker .elements(160)
2911*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2912*4bdc9457SAndroid Build Coastguard Worker }
2913*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2,elements_div_160)2914*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2, elements_div_160) {
2915*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2916*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 320; elements < 1600; elements += 160) {
2917*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2918*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2919*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2920*4bdc9457SAndroid Build Coastguard Worker }
2921*4bdc9457SAndroid Build Coastguard Worker }
2922*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2,elements_lt_160)2923*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2, elements_lt_160) {
2924*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2925*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 160; elements++) {
2926*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2927*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2928*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2929*4bdc9457SAndroid Build Coastguard Worker }
2930*4bdc9457SAndroid Build Coastguard Worker }
2931*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2,elements_gt_160)2932*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC2, elements_gt_160) {
2933*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2934*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 161; elements < 320; elements++) {
2935*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2936*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2937*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
2938*4bdc9457SAndroid Build Coastguard Worker }
2939*4bdc9457SAndroid Build Coastguard Worker }
2940*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2941*4bdc9457SAndroid Build Coastguard Worker
2942*4bdc9457SAndroid Build Coastguard Worker
2943*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5,elements_eq_160)2944*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5, elements_eq_160) {
2945*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2946*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2947*4bdc9457SAndroid Build Coastguard Worker .elements(160)
2948*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc5, xnn_init_f32_expminus_avx512_rr1_p5_params);
2949*4bdc9457SAndroid Build Coastguard Worker }
2950*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5,elements_div_160)2951*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5, elements_div_160) {
2952*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2953*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 320; elements < 1600; elements += 160) {
2954*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2955*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2956*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc5, xnn_init_f32_expminus_avx512_rr1_p5_params);
2957*4bdc9457SAndroid Build Coastguard Worker }
2958*4bdc9457SAndroid Build Coastguard Worker }
2959*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5,elements_lt_160)2960*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5, elements_lt_160) {
2961*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2962*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 160; elements++) {
2963*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2964*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2965*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc5, xnn_init_f32_expminus_avx512_rr1_p5_params);
2966*4bdc9457SAndroid Build Coastguard Worker }
2967*4bdc9457SAndroid Build Coastguard Worker }
2968*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5,elements_gt_160)2969*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X160_ACC5, elements_gt_160) {
2970*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2971*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 161; elements < 320; elements++) {
2972*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2973*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2974*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x160_acc5, xnn_init_f32_expminus_avx512_rr1_p5_params);
2975*4bdc9457SAndroid Build Coastguard Worker }
2976*4bdc9457SAndroid Build Coastguard Worker }
2977*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
2978*4bdc9457SAndroid Build Coastguard Worker
2979*4bdc9457SAndroid Build Coastguard Worker
2980*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192,elements_eq_192)2981*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192, elements_eq_192) {
2982*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2983*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2984*4bdc9457SAndroid Build Coastguard Worker .elements(192)
2985*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192, xnn_init_f32_expminus_avx512_rr1_p5_params);
2986*4bdc9457SAndroid Build Coastguard Worker }
2987*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192,elements_div_192)2988*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192, elements_div_192) {
2989*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2990*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 384; elements < 1920; elements += 192) {
2991*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
2992*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
2993*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192, xnn_init_f32_expminus_avx512_rr1_p5_params);
2994*4bdc9457SAndroid Build Coastguard Worker }
2995*4bdc9457SAndroid Build Coastguard Worker }
2996*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192,elements_lt_192)2997*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192, elements_lt_192) {
2998*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
2999*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 192; elements++) {
3000*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3001*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3002*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192, xnn_init_f32_expminus_avx512_rr1_p5_params);
3003*4bdc9457SAndroid Build Coastguard Worker }
3004*4bdc9457SAndroid Build Coastguard Worker }
3005*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192,elements_gt_192)3006*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192, elements_gt_192) {
3007*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3008*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 193; elements < 384; elements++) {
3009*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3010*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3011*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192, xnn_init_f32_expminus_avx512_rr1_p5_params);
3012*4bdc9457SAndroid Build Coastguard Worker }
3013*4bdc9457SAndroid Build Coastguard Worker }
3014*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3015*4bdc9457SAndroid Build Coastguard Worker
3016*4bdc9457SAndroid Build Coastguard Worker
3017*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2,elements_eq_192)3018*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2, elements_eq_192) {
3019*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3020*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3021*4bdc9457SAndroid Build Coastguard Worker .elements(192)
3022*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
3023*4bdc9457SAndroid Build Coastguard Worker }
3024*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2,elements_div_192)3025*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2, elements_div_192) {
3026*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3027*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 384; elements < 1920; elements += 192) {
3028*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3029*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3030*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
3031*4bdc9457SAndroid Build Coastguard Worker }
3032*4bdc9457SAndroid Build Coastguard Worker }
3033*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2,elements_lt_192)3034*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2, elements_lt_192) {
3035*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3036*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 192; elements++) {
3037*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3038*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3039*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
3040*4bdc9457SAndroid Build Coastguard Worker }
3041*4bdc9457SAndroid Build Coastguard Worker }
3042*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2,elements_gt_192)3043*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC2, elements_gt_192) {
3044*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3045*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 193; elements < 384; elements++) {
3046*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3047*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3048*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc2, xnn_init_f32_expminus_avx512_rr1_p5_params);
3049*4bdc9457SAndroid Build Coastguard Worker }
3050*4bdc9457SAndroid Build Coastguard Worker }
3051*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3052*4bdc9457SAndroid Build Coastguard Worker
3053*4bdc9457SAndroid Build Coastguard Worker
3054*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3,elements_eq_192)3055*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3, elements_eq_192) {
3056*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3057*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3058*4bdc9457SAndroid Build Coastguard Worker .elements(192)
3059*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
3060*4bdc9457SAndroid Build Coastguard Worker }
3061*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3,elements_div_192)3062*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3, elements_div_192) {
3063*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3064*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 384; elements < 1920; elements += 192) {
3065*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3066*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3067*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
3068*4bdc9457SAndroid Build Coastguard Worker }
3069*4bdc9457SAndroid Build Coastguard Worker }
3070*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3,elements_lt_192)3071*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3, elements_lt_192) {
3072*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3073*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 192; elements++) {
3074*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3075*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3076*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
3077*4bdc9457SAndroid Build Coastguard Worker }
3078*4bdc9457SAndroid Build Coastguard Worker }
3079*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3,elements_gt_192)3080*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC3, elements_gt_192) {
3081*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3082*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 193; elements < 384; elements++) {
3083*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3084*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3085*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc3, xnn_init_f32_expminus_avx512_rr1_p5_params);
3086*4bdc9457SAndroid Build Coastguard Worker }
3087*4bdc9457SAndroid Build Coastguard Worker }
3088*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3089*4bdc9457SAndroid Build Coastguard Worker
3090*4bdc9457SAndroid Build Coastguard Worker
3091*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_X86 || XNN_ARCH_X86_64
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6,elements_eq_192)3092*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6, elements_eq_192) {
3093*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3094*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3095*4bdc9457SAndroid Build Coastguard Worker .elements(192)
3096*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc6, xnn_init_f32_expminus_avx512_rr1_p5_params);
3097*4bdc9457SAndroid Build Coastguard Worker }
3098*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6,elements_div_192)3099*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6, elements_div_192) {
3100*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3101*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 384; elements < 1920; elements += 192) {
3102*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3103*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3104*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc6, xnn_init_f32_expminus_avx512_rr1_p5_params);
3105*4bdc9457SAndroid Build Coastguard Worker }
3106*4bdc9457SAndroid Build Coastguard Worker }
3107*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6,elements_lt_192)3108*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6, elements_lt_192) {
3109*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3110*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 192; elements++) {
3111*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3112*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3113*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc6, xnn_init_f32_expminus_avx512_rr1_p5_params);
3114*4bdc9457SAndroid Build Coastguard Worker }
3115*4bdc9457SAndroid Build Coastguard Worker }
3116*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6,elements_gt_192)3117*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__AVX512F_RR1_P5_SCALEF_X192_ACC6, elements_gt_192) {
3118*4bdc9457SAndroid Build Coastguard Worker TEST_REQUIRES_X86_AVX512F;
3119*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 193; elements < 384; elements++) {
3120*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3121*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3122*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__avx512f_rr1_p5_scalef_x192_acc6, xnn_init_f32_expminus_avx512_rr1_p5_params);
3123*4bdc9457SAndroid Build Coastguard Worker }
3124*4bdc9457SAndroid Build Coastguard Worker }
3125*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_X86 || XNN_ARCH_X86_64
3126*4bdc9457SAndroid Build Coastguard Worker
3127*4bdc9457SAndroid Build Coastguard Worker
3128*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4,elements_eq_4)3129*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4, elements_eq_4) {
3130*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3131*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3132*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3133*4bdc9457SAndroid Build Coastguard Worker }
3134*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4,elements_div_4)3135*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4, elements_div_4) {
3136*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3137*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3138*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3139*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3140*4bdc9457SAndroid Build Coastguard Worker }
3141*4bdc9457SAndroid Build Coastguard Worker }
3142*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4,elements_lt_4)3143*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4, elements_lt_4) {
3144*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3145*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3146*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3147*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3148*4bdc9457SAndroid Build Coastguard Worker }
3149*4bdc9457SAndroid Build Coastguard Worker }
3150*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4,elements_gt_4)3151*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X4, elements_gt_4) {
3152*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3153*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3154*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3155*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3156*4bdc9457SAndroid Build Coastguard Worker }
3157*4bdc9457SAndroid Build Coastguard Worker }
3158*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3159*4bdc9457SAndroid Build Coastguard Worker
3160*4bdc9457SAndroid Build Coastguard Worker
3161*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8,elements_eq_8)3162*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8, elements_eq_8) {
3163*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3164*4bdc9457SAndroid Build Coastguard Worker .elements(8)
3165*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3166*4bdc9457SAndroid Build Coastguard Worker }
3167*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8,elements_div_8)3168*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8, elements_div_8) {
3169*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
3170*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3171*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3172*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3173*4bdc9457SAndroid Build Coastguard Worker }
3174*4bdc9457SAndroid Build Coastguard Worker }
3175*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8,elements_lt_8)3176*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8, elements_lt_8) {
3177*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
3178*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3179*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3180*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3181*4bdc9457SAndroid Build Coastguard Worker }
3182*4bdc9457SAndroid Build Coastguard Worker }
3183*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8,elements_gt_8)3184*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8, elements_gt_8) {
3185*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
3186*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3187*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3188*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3189*4bdc9457SAndroid Build Coastguard Worker }
3190*4bdc9457SAndroid Build Coastguard Worker }
3191*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3192*4bdc9457SAndroid Build Coastguard Worker
3193*4bdc9457SAndroid Build Coastguard Worker
3194*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2,elements_eq_8)3195*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2, elements_eq_8) {
3196*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3197*4bdc9457SAndroid Build Coastguard Worker .elements(8)
3198*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3199*4bdc9457SAndroid Build Coastguard Worker }
3200*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2,elements_div_8)3201*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2, elements_div_8) {
3202*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 16; elements < 80; elements += 8) {
3203*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3204*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3205*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3206*4bdc9457SAndroid Build Coastguard Worker }
3207*4bdc9457SAndroid Build Coastguard Worker }
3208*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2,elements_lt_8)3209*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2, elements_lt_8) {
3210*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 8; elements++) {
3211*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3212*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3213*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3214*4bdc9457SAndroid Build Coastguard Worker }
3215*4bdc9457SAndroid Build Coastguard Worker }
3216*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2,elements_gt_8)3217*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X8_ACC2, elements_gt_8) {
3218*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 9; elements < 16; elements++) {
3219*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3220*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3221*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x8_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3222*4bdc9457SAndroid Build Coastguard Worker }
3223*4bdc9457SAndroid Build Coastguard Worker }
3224*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3225*4bdc9457SAndroid Build Coastguard Worker
3226*4bdc9457SAndroid Build Coastguard Worker
3227*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12,elements_eq_12)3228*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12, elements_eq_12) {
3229*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3230*4bdc9457SAndroid Build Coastguard Worker .elements(12)
3231*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3232*4bdc9457SAndroid Build Coastguard Worker }
3233*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12,elements_div_12)3234*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12, elements_div_12) {
3235*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
3236*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3237*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3238*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3239*4bdc9457SAndroid Build Coastguard Worker }
3240*4bdc9457SAndroid Build Coastguard Worker }
3241*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12,elements_lt_12)3242*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12, elements_lt_12) {
3243*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
3244*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3245*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3246*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3247*4bdc9457SAndroid Build Coastguard Worker }
3248*4bdc9457SAndroid Build Coastguard Worker }
3249*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12,elements_gt_12)3250*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12, elements_gt_12) {
3251*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
3252*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3253*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3254*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3255*4bdc9457SAndroid Build Coastguard Worker }
3256*4bdc9457SAndroid Build Coastguard Worker }
3257*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3258*4bdc9457SAndroid Build Coastguard Worker
3259*4bdc9457SAndroid Build Coastguard Worker
3260*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2,elements_eq_12)3261*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2, elements_eq_12) {
3262*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3263*4bdc9457SAndroid Build Coastguard Worker .elements(12)
3264*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3265*4bdc9457SAndroid Build Coastguard Worker }
3266*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2,elements_div_12)3267*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2, elements_div_12) {
3268*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
3269*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3270*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3271*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3272*4bdc9457SAndroid Build Coastguard Worker }
3273*4bdc9457SAndroid Build Coastguard Worker }
3274*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2,elements_lt_12)3275*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2, elements_lt_12) {
3276*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
3277*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3278*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3279*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3280*4bdc9457SAndroid Build Coastguard Worker }
3281*4bdc9457SAndroid Build Coastguard Worker }
3282*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2,elements_gt_12)3283*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC2, elements_gt_12) {
3284*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
3285*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3286*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3287*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3288*4bdc9457SAndroid Build Coastguard Worker }
3289*4bdc9457SAndroid Build Coastguard Worker }
3290*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3291*4bdc9457SAndroid Build Coastguard Worker
3292*4bdc9457SAndroid Build Coastguard Worker
3293*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3,elements_eq_12)3294*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3, elements_eq_12) {
3295*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3296*4bdc9457SAndroid Build Coastguard Worker .elements(12)
3297*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc3, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3298*4bdc9457SAndroid Build Coastguard Worker }
3299*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3,elements_div_12)3300*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3, elements_div_12) {
3301*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 24; elements < 120; elements += 12) {
3302*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3303*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3304*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc3, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3305*4bdc9457SAndroid Build Coastguard Worker }
3306*4bdc9457SAndroid Build Coastguard Worker }
3307*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3,elements_lt_12)3308*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3, elements_lt_12) {
3309*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 12; elements++) {
3310*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3311*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3312*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc3, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3313*4bdc9457SAndroid Build Coastguard Worker }
3314*4bdc9457SAndroid Build Coastguard Worker }
3315*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3,elements_gt_12)3316*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X12_ACC3, elements_gt_12) {
3317*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 13; elements < 24; elements++) {
3318*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3319*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3320*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x12_acc3, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3321*4bdc9457SAndroid Build Coastguard Worker }
3322*4bdc9457SAndroid Build Coastguard Worker }
3323*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3324*4bdc9457SAndroid Build Coastguard Worker
3325*4bdc9457SAndroid Build Coastguard Worker
3326*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16,elements_eq_16)3327*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16, elements_eq_16) {
3328*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3329*4bdc9457SAndroid Build Coastguard Worker .elements(16)
3330*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3331*4bdc9457SAndroid Build Coastguard Worker }
3332*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16,elements_div_16)3333*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16, elements_div_16) {
3334*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
3335*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3336*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3337*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3338*4bdc9457SAndroid Build Coastguard Worker }
3339*4bdc9457SAndroid Build Coastguard Worker }
3340*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16,elements_lt_16)3341*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16, elements_lt_16) {
3342*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
3343*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3344*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3345*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3346*4bdc9457SAndroid Build Coastguard Worker }
3347*4bdc9457SAndroid Build Coastguard Worker }
3348*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16,elements_gt_16)3349*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16, elements_gt_16) {
3350*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
3351*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3352*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3353*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3354*4bdc9457SAndroid Build Coastguard Worker }
3355*4bdc9457SAndroid Build Coastguard Worker }
3356*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3357*4bdc9457SAndroid Build Coastguard Worker
3358*4bdc9457SAndroid Build Coastguard Worker
3359*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2,elements_eq_16)3360*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2, elements_eq_16) {
3361*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3362*4bdc9457SAndroid Build Coastguard Worker .elements(16)
3363*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3364*4bdc9457SAndroid Build Coastguard Worker }
3365*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2,elements_div_16)3366*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2, elements_div_16) {
3367*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
3368*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3369*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3370*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3371*4bdc9457SAndroid Build Coastguard Worker }
3372*4bdc9457SAndroid Build Coastguard Worker }
3373*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2,elements_lt_16)3374*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2, elements_lt_16) {
3375*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
3376*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3377*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3378*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3379*4bdc9457SAndroid Build Coastguard Worker }
3380*4bdc9457SAndroid Build Coastguard Worker }
3381*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2,elements_gt_16)3382*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC2, elements_gt_16) {
3383*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
3384*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3385*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3386*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3387*4bdc9457SAndroid Build Coastguard Worker }
3388*4bdc9457SAndroid Build Coastguard Worker }
3389*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3390*4bdc9457SAndroid Build Coastguard Worker
3391*4bdc9457SAndroid Build Coastguard Worker
3392*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4,elements_eq_16)3393*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4, elements_eq_16) {
3394*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3395*4bdc9457SAndroid Build Coastguard Worker .elements(16)
3396*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3397*4bdc9457SAndroid Build Coastguard Worker }
3398*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4,elements_div_16)3399*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4, elements_div_16) {
3400*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 32; elements < 160; elements += 16) {
3401*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3402*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3403*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3404*4bdc9457SAndroid Build Coastguard Worker }
3405*4bdc9457SAndroid Build Coastguard Worker }
3406*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4,elements_lt_16)3407*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4, elements_lt_16) {
3408*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 16; elements++) {
3409*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3410*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3411*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3412*4bdc9457SAndroid Build Coastguard Worker }
3413*4bdc9457SAndroid Build Coastguard Worker }
3414*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4,elements_gt_16)3415*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X16_ACC4, elements_gt_16) {
3416*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 17; elements < 32; elements++) {
3417*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3418*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3419*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x16_acc4, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3420*4bdc9457SAndroid Build Coastguard Worker }
3421*4bdc9457SAndroid Build Coastguard Worker }
3422*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3423*4bdc9457SAndroid Build Coastguard Worker
3424*4bdc9457SAndroid Build Coastguard Worker
3425*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20,elements_eq_20)3426*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20, elements_eq_20) {
3427*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3428*4bdc9457SAndroid Build Coastguard Worker .elements(20)
3429*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3430*4bdc9457SAndroid Build Coastguard Worker }
3431*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20,elements_div_20)3432*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20, elements_div_20) {
3433*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
3434*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3435*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3436*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3437*4bdc9457SAndroid Build Coastguard Worker }
3438*4bdc9457SAndroid Build Coastguard Worker }
3439*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20,elements_lt_20)3440*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20, elements_lt_20) {
3441*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
3442*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3443*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3444*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3445*4bdc9457SAndroid Build Coastguard Worker }
3446*4bdc9457SAndroid Build Coastguard Worker }
3447*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20,elements_gt_20)3448*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20, elements_gt_20) {
3449*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
3450*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3451*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3452*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3453*4bdc9457SAndroid Build Coastguard Worker }
3454*4bdc9457SAndroid Build Coastguard Worker }
3455*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3456*4bdc9457SAndroid Build Coastguard Worker
3457*4bdc9457SAndroid Build Coastguard Worker
3458*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2,elements_eq_20)3459*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2, elements_eq_20) {
3460*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3461*4bdc9457SAndroid Build Coastguard Worker .elements(20)
3462*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3463*4bdc9457SAndroid Build Coastguard Worker }
3464*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2,elements_div_20)3465*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2, elements_div_20) {
3466*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
3467*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3468*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3469*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3470*4bdc9457SAndroid Build Coastguard Worker }
3471*4bdc9457SAndroid Build Coastguard Worker }
3472*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2,elements_lt_20)3473*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2, elements_lt_20) {
3474*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
3475*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3476*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3477*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3478*4bdc9457SAndroid Build Coastguard Worker }
3479*4bdc9457SAndroid Build Coastguard Worker }
3480*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2,elements_gt_20)3481*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC2, elements_gt_20) {
3482*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
3483*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3484*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3485*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc2, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3486*4bdc9457SAndroid Build Coastguard Worker }
3487*4bdc9457SAndroid Build Coastguard Worker }
3488*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3489*4bdc9457SAndroid Build Coastguard Worker
3490*4bdc9457SAndroid Build Coastguard Worker
3491*4bdc9457SAndroid Build Coastguard Worker #if XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5,elements_eq_20)3492*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5, elements_eq_20) {
3493*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3494*4bdc9457SAndroid Build Coastguard Worker .elements(20)
3495*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc5, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3496*4bdc9457SAndroid Build Coastguard Worker }
3497*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5,elements_div_20)3498*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5, elements_div_20) {
3499*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 40; elements < 200; elements += 20) {
3500*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3501*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3502*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc5, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3503*4bdc9457SAndroid Build Coastguard Worker }
3504*4bdc9457SAndroid Build Coastguard Worker }
3505*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5,elements_lt_20)3506*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5, elements_lt_20) {
3507*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 20; elements++) {
3508*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3509*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3510*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc5, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3511*4bdc9457SAndroid Build Coastguard Worker }
3512*4bdc9457SAndroid Build Coastguard Worker }
3513*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5,elements_gt_20)3514*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__WASMSIMD_RR2_P5_X20_ACC5, elements_gt_20) {
3515*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 21; elements < 40; elements++) {
3516*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3517*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3518*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__wasmsimd_rr2_p5_x20_acc5, xnn_init_f32_expminus_wasmsimd_rr2_p5_params);
3519*4bdc9457SAndroid Build Coastguard Worker }
3520*4bdc9457SAndroid Build Coastguard Worker }
3521*4bdc9457SAndroid Build Coastguard Worker #endif // XNN_ARCH_WASMSIMD || XNN_ARCH_WASMRELAXEDSIMD
3522*4bdc9457SAndroid Build Coastguard Worker
3523*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X1,elements_eq_1)3524*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X1, elements_eq_1) {
3525*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3526*4bdc9457SAndroid Build Coastguard Worker .elements(1)
3527*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x1, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3528*4bdc9457SAndroid Build Coastguard Worker }
3529*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X1,elements_gt_1)3530*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X1, elements_gt_1) {
3531*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 2; elements < 10; elements++) {
3532*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3533*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3534*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x1, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3535*4bdc9457SAndroid Build Coastguard Worker }
3536*4bdc9457SAndroid Build Coastguard Worker }
3537*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2,elements_eq_2)3538*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2, elements_eq_2) {
3539*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3540*4bdc9457SAndroid Build Coastguard Worker .elements(2)
3541*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3542*4bdc9457SAndroid Build Coastguard Worker }
3543*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2,elements_div_2)3544*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2, elements_div_2) {
3545*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 4; elements < 20; elements += 2) {
3546*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3547*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3548*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3549*4bdc9457SAndroid Build Coastguard Worker }
3550*4bdc9457SAndroid Build Coastguard Worker }
3551*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2,elements_lt_2)3552*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2, elements_lt_2) {
3553*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 2; elements++) {
3554*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3555*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3556*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3557*4bdc9457SAndroid Build Coastguard Worker }
3558*4bdc9457SAndroid Build Coastguard Worker }
3559*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2,elements_gt_2)3560*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2, elements_gt_2) {
3561*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 3; elements < 4; elements++) {
3562*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3563*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3564*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3565*4bdc9457SAndroid Build Coastguard Worker }
3566*4bdc9457SAndroid Build Coastguard Worker }
3567*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2,elements_eq_2)3568*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2, elements_eq_2) {
3569*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3570*4bdc9457SAndroid Build Coastguard Worker .elements(2)
3571*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3572*4bdc9457SAndroid Build Coastguard Worker }
3573*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2,elements_div_2)3574*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2, elements_div_2) {
3575*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 4; elements < 20; elements += 2) {
3576*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3577*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3578*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3579*4bdc9457SAndroid Build Coastguard Worker }
3580*4bdc9457SAndroid Build Coastguard Worker }
3581*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2,elements_lt_2)3582*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2, elements_lt_2) {
3583*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 2; elements++) {
3584*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3585*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3586*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3587*4bdc9457SAndroid Build Coastguard Worker }
3588*4bdc9457SAndroid Build Coastguard Worker }
3589*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2,elements_gt_2)3590*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X2_ACC2, elements_gt_2) {
3591*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 3; elements < 4; elements++) {
3592*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3593*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3594*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x2_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3595*4bdc9457SAndroid Build Coastguard Worker }
3596*4bdc9457SAndroid Build Coastguard Worker }
3597*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4,elements_eq_4)3598*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4, elements_eq_4) {
3599*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3600*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3601*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3602*4bdc9457SAndroid Build Coastguard Worker }
3603*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4,elements_div_4)3604*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4, elements_div_4) {
3605*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3606*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3607*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3608*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3609*4bdc9457SAndroid Build Coastguard Worker }
3610*4bdc9457SAndroid Build Coastguard Worker }
3611*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4,elements_lt_4)3612*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4, elements_lt_4) {
3613*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3614*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3615*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3616*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3617*4bdc9457SAndroid Build Coastguard Worker }
3618*4bdc9457SAndroid Build Coastguard Worker }
3619*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4,elements_gt_4)3620*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4, elements_gt_4) {
3621*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3622*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3623*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3624*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3625*4bdc9457SAndroid Build Coastguard Worker }
3626*4bdc9457SAndroid Build Coastguard Worker }
3627*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2,elements_eq_4)3628*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2, elements_eq_4) {
3629*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3630*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3631*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3632*4bdc9457SAndroid Build Coastguard Worker }
3633*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2,elements_div_4)3634*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2, elements_div_4) {
3635*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3636*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3637*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3638*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3639*4bdc9457SAndroid Build Coastguard Worker }
3640*4bdc9457SAndroid Build Coastguard Worker }
3641*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2,elements_lt_4)3642*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2, elements_lt_4) {
3643*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3644*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3645*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3646*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3647*4bdc9457SAndroid Build Coastguard Worker }
3648*4bdc9457SAndroid Build Coastguard Worker }
3649*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2,elements_gt_4)3650*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC2, elements_gt_4) {
3651*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3652*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3653*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3654*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc2, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3655*4bdc9457SAndroid Build Coastguard Worker }
3656*4bdc9457SAndroid Build Coastguard Worker }
3657*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4,elements_eq_4)3658*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4, elements_eq_4) {
3659*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3660*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3661*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3662*4bdc9457SAndroid Build Coastguard Worker }
3663*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4,elements_div_4)3664*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4, elements_div_4) {
3665*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3666*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3667*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3668*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3669*4bdc9457SAndroid Build Coastguard Worker }
3670*4bdc9457SAndroid Build Coastguard Worker }
3671*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4,elements_lt_4)3672*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4, elements_lt_4) {
3673*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3674*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3675*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3676*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3677*4bdc9457SAndroid Build Coastguard Worker }
3678*4bdc9457SAndroid Build Coastguard Worker }
3679*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4,elements_gt_4)3680*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_LUT64_P2_X4_ACC4, elements_gt_4) {
3681*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3682*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3683*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3684*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_lut64_p2_x4_acc4, xnn_init_f32_expminus_scalar_rr2_lut64_p2_params);
3685*4bdc9457SAndroid Build Coastguard Worker }
3686*4bdc9457SAndroid Build Coastguard Worker }
3687*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X1,elements_eq_1)3688*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X1, elements_eq_1) {
3689*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3690*4bdc9457SAndroid Build Coastguard Worker .elements(1)
3691*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x1, xnn_init_f32_expminus_scalar_rr2_p5_params);
3692*4bdc9457SAndroid Build Coastguard Worker }
3693*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X1,elements_gt_1)3694*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X1, elements_gt_1) {
3695*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 2; elements < 10; elements++) {
3696*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3697*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3698*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x1, xnn_init_f32_expminus_scalar_rr2_p5_params);
3699*4bdc9457SAndroid Build Coastguard Worker }
3700*4bdc9457SAndroid Build Coastguard Worker }
3701*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2,elements_eq_2)3702*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2, elements_eq_2) {
3703*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3704*4bdc9457SAndroid Build Coastguard Worker .elements(2)
3705*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3706*4bdc9457SAndroid Build Coastguard Worker }
3707*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2,elements_div_2)3708*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2, elements_div_2) {
3709*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 4; elements < 20; elements += 2) {
3710*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3711*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3712*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3713*4bdc9457SAndroid Build Coastguard Worker }
3714*4bdc9457SAndroid Build Coastguard Worker }
3715*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2,elements_lt_2)3716*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2, elements_lt_2) {
3717*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 2; elements++) {
3718*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3719*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3720*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3721*4bdc9457SAndroid Build Coastguard Worker }
3722*4bdc9457SAndroid Build Coastguard Worker }
3723*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2,elements_gt_2)3724*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2, elements_gt_2) {
3725*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 3; elements < 4; elements++) {
3726*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3727*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3728*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3729*4bdc9457SAndroid Build Coastguard Worker }
3730*4bdc9457SAndroid Build Coastguard Worker }
3731*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2,elements_eq_2)3732*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2, elements_eq_2) {
3733*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3734*4bdc9457SAndroid Build Coastguard Worker .elements(2)
3735*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3736*4bdc9457SAndroid Build Coastguard Worker }
3737*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2,elements_div_2)3738*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2, elements_div_2) {
3739*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 4; elements < 20; elements += 2) {
3740*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3741*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3742*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3743*4bdc9457SAndroid Build Coastguard Worker }
3744*4bdc9457SAndroid Build Coastguard Worker }
3745*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2,elements_lt_2)3746*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2, elements_lt_2) {
3747*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 2; elements++) {
3748*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3749*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3750*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3751*4bdc9457SAndroid Build Coastguard Worker }
3752*4bdc9457SAndroid Build Coastguard Worker }
3753*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2,elements_gt_2)3754*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X2_ACC2, elements_gt_2) {
3755*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 3; elements < 4; elements++) {
3756*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3757*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3758*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x2_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3759*4bdc9457SAndroid Build Coastguard Worker }
3760*4bdc9457SAndroid Build Coastguard Worker }
3761*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4,elements_eq_4)3762*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4, elements_eq_4) {
3763*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3764*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3765*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3766*4bdc9457SAndroid Build Coastguard Worker }
3767*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4,elements_div_4)3768*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4, elements_div_4) {
3769*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3770*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3771*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3772*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3773*4bdc9457SAndroid Build Coastguard Worker }
3774*4bdc9457SAndroid Build Coastguard Worker }
3775*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4,elements_lt_4)3776*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4, elements_lt_4) {
3777*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3778*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3779*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3780*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3781*4bdc9457SAndroid Build Coastguard Worker }
3782*4bdc9457SAndroid Build Coastguard Worker }
3783*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4,elements_gt_4)3784*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4, elements_gt_4) {
3785*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3786*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3787*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3788*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3789*4bdc9457SAndroid Build Coastguard Worker }
3790*4bdc9457SAndroid Build Coastguard Worker }
3791*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2,elements_eq_4)3792*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2, elements_eq_4) {
3793*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3794*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3795*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3796*4bdc9457SAndroid Build Coastguard Worker }
3797*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2,elements_div_4)3798*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2, elements_div_4) {
3799*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3800*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3801*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3802*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3803*4bdc9457SAndroid Build Coastguard Worker }
3804*4bdc9457SAndroid Build Coastguard Worker }
3805*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2,elements_lt_4)3806*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2, elements_lt_4) {
3807*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3808*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3809*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3810*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3811*4bdc9457SAndroid Build Coastguard Worker }
3812*4bdc9457SAndroid Build Coastguard Worker }
3813*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2,elements_gt_4)3814*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC2, elements_gt_4) {
3815*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3816*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3817*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3818*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc2, xnn_init_f32_expminus_scalar_rr2_p5_params);
3819*4bdc9457SAndroid Build Coastguard Worker }
3820*4bdc9457SAndroid Build Coastguard Worker }
3821*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4,elements_eq_4)3822*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4, elements_eq_4) {
3823*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3824*4bdc9457SAndroid Build Coastguard Worker .elements(4)
3825*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3826*4bdc9457SAndroid Build Coastguard Worker }
3827*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4,elements_div_4)3828*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4, elements_div_4) {
3829*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 8; elements < 40; elements += 4) {
3830*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3831*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3832*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3833*4bdc9457SAndroid Build Coastguard Worker }
3834*4bdc9457SAndroid Build Coastguard Worker }
3835*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4,elements_lt_4)3836*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4, elements_lt_4) {
3837*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 1; elements < 4; elements++) {
3838*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3839*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3840*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3841*4bdc9457SAndroid Build Coastguard Worker }
3842*4bdc9457SAndroid Build Coastguard Worker }
3843*4bdc9457SAndroid Build Coastguard Worker
TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4,elements_gt_4)3844*4bdc9457SAndroid Build Coastguard Worker TEST(F32_RADDSTOREEXPMINUSMAX__SCALAR_RR2_P5_X4_ACC4, elements_gt_4) {
3845*4bdc9457SAndroid Build Coastguard Worker for (size_t elements = 5; elements < 8; elements++) {
3846*4bdc9457SAndroid Build Coastguard Worker RAddStoreExpMinusMaxMicrokernelTester()
3847*4bdc9457SAndroid Build Coastguard Worker .elements(elements)
3848*4bdc9457SAndroid Build Coastguard Worker .Test(xnn_f32_raddstoreexpminusmax_ukernel__scalar_rr2_p5_x4_acc4, xnn_init_f32_expminus_scalar_rr2_p5_params);
3849*4bdc9457SAndroid Build Coastguard Worker }
3850*4bdc9457SAndroid Build Coastguard Worker }