File: laneselect.c

package info (click to toggle)
simde 0.8.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie, trixie-backports
  • size: 58,264 kB
  • sloc: ansic: 817,393; sh: 315; makefile: 45; python: 26
file content (351 lines) | stat: -rw-r--r-- 26,719 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
/* Copyright (c) 2021 Evan Nemerson <evan@nemerson.com>
 *
 * Permission is hereby granted, free of charge, to any person
 * obtaining a copy of this software and associated documentation
 * files (the "Software"), to deal in the Software without
 * restriction, including without limitation the rights to use, copy,
 * modify, merge, publish, distribute, sublicense, and/or sell copies
 * of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

#define SIMDE_TEST_WASM_RELAXED_SIMD_INSN laneselect
#include "../../../simde/wasm/relaxed-simd.h"
#include "test-relaxed-simd.h"

static int
test_simde_wasm_i8x16_relaxed_laneselect(SIMDE_MUNIT_TEST_ARGS) {
  #if 1
    SIMDE_TEST_STRUCT_MODIFIERS struct {
      int8_t a[sizeof(simde_v128_t) / sizeof(int8_t)];
      int8_t b[sizeof(simde_v128_t) / sizeof(int8_t)];
      int8_t mask[sizeof(simde_v128_t) / sizeof(int8_t)];
      int8_t r[sizeof(simde_v128_t) / sizeof(int8_t)];
    } test_vec[] = {
      { { -INT8_C(  47),  INT8_C(  48), -INT8_C(  38),  INT8_C(  57), -INT8_C(  47), -INT8_C(  71), -INT8_C(  70),  INT8_C( 114),
          -INT8_C( 114), -INT8_C(   4), -INT8_C(  13),  INT8_C(  88),  INT8_C(  35),  INT8_C(  87),  INT8_C(  26),  INT8_C(  62) },
        {  INT8_C( 118), -INT8_C(  57),      INT8_MAX, -INT8_C(   1),  INT8_C( 107), -INT8_C(  24),  INT8_C( 124),  INT8_C(  76),
           INT8_C(  41),  INT8_C(  29), -INT8_C(  49), -INT8_C(  45), -INT8_C( 119),  INT8_C(  57),  INT8_C(  79),  INT8_C(  90) },
        {  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0),
           INT8_C(   0), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0) },
        {  INT8_C( 118), -INT8_C(  57), -INT8_C(  38), -INT8_C(   1), -INT8_C(  47), -INT8_C(  24), -INT8_C(  70),  INT8_C(  76),
           INT8_C(  41), -INT8_C(   4), -INT8_C(  13), -INT8_C(  45),  INT8_C(  35),  INT8_C(  87),  INT8_C(  26),  INT8_C(  90) } },
      { { -INT8_C(  87),  INT8_C(  43),  INT8_C( 109),  INT8_C(  21),  INT8_C(  20), -INT8_C(  23),  INT8_C(  97),  INT8_C(  61),
           INT8_C(   6),  INT8_C(  48),  INT8_C(  17), -INT8_C( 113),  INT8_C( 105),  INT8_C(  96), -INT8_C(  23), -INT8_C(  45) },
        { -INT8_C( 119),  INT8_C( 125),  INT8_C(  13),  INT8_C( 107), -INT8_C(  52), -INT8_C(  70), -INT8_C(  37),  INT8_C(  23),
           INT8_C(  90), -INT8_C(  92), -INT8_C( 123),  INT8_C(  82), -INT8_C( 122),  INT8_C(  49), -INT8_C(  65),  INT8_C(  48) },
        {  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),
          -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1) },
        { -INT8_C( 119),  INT8_C( 125),  INT8_C(  13),  INT8_C( 107), -INT8_C(  52), -INT8_C(  23),  INT8_C(  97),  INT8_C(  23),
           INT8_C(   6),  INT8_C(  48),  INT8_C(  17),  INT8_C(  82), -INT8_C( 122),  INT8_C(  96), -INT8_C(  65), -INT8_C(  45) } },
      { {  INT8_C(  17),  INT8_C(  32),  INT8_C(  19), -INT8_C(  35), -INT8_C(  38), -INT8_C(  17), -INT8_C(  12),  INT8_C(  53),
          -INT8_C( 109),  INT8_C( 121), -INT8_C( 121),  INT8_C(  25), -INT8_C(  85),  INT8_C(  70),  INT8_C(  73),  INT8_C(   8) },
        {  INT8_C( 115), -INT8_C( 114),  INT8_C( 121), -INT8_C( 120),  INT8_C(  52),  INT8_C(  39), -INT8_C(  92),  INT8_C(  10),
          -INT8_C(  25),  INT8_C(  78),  INT8_C(  74),  INT8_C(   6), -INT8_C(  30),  INT8_C(  92), -INT8_C(  81), -INT8_C(  12) },
        {  INT8_C(   0), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),
           INT8_C(   0),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1) },
        {  INT8_C( 115),  INT8_C(  32),  INT8_C(  19), -INT8_C( 120), -INT8_C(  38), -INT8_C(  17), -INT8_C(  12),  INT8_C(  10),
          -INT8_C(  25),  INT8_C(  78),  INT8_C(  74),  INT8_C(  25), -INT8_C(  30),  INT8_C(  70),  INT8_C(  73),  INT8_C(   8) } },
      { {  INT8_C(  54),  INT8_C( 107),  INT8_C(  85),  INT8_C( 106), -INT8_C( 109), -INT8_C(   7),  INT8_C( 117),  INT8_C( 122),
           INT8_C(  71), -INT8_C(  65),      INT8_MIN,  INT8_C(  42),  INT8_C(  27),  INT8_C(  47),  INT8_C(  30), -INT8_C( 104) },
        { -INT8_C(  14), -INT8_C(  17), -INT8_C(  17), -INT8_C(  93), -INT8_C(  75),  INT8_C( 123), -INT8_C(  24), -INT8_C(  11),
          -INT8_C( 114),  INT8_C(  70), -INT8_C(  33), -INT8_C(  25), -INT8_C(  19), -INT8_C(  46), -INT8_C(  76),  INT8_C(  35) },
        {  INT8_C(   0),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),
          -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1) },
        { -INT8_C(  14), -INT8_C(  17),  INT8_C(  85),  INT8_C( 106), -INT8_C(  75),  INT8_C( 123), -INT8_C(  24), -INT8_C(  11),
           INT8_C(  71), -INT8_C(  65), -INT8_C(  33),  INT8_C(  42),  INT8_C(  27),  INT8_C(  47), -INT8_C(  76), -INT8_C( 104) } },
      { { -INT8_C( 127),  INT8_C( 100), -INT8_C( 112),  INT8_C(  54), -INT8_C(  33),  INT8_C( 120),  INT8_C(  43),  INT8_C( 109),
          -INT8_C(  66),  INT8_C(  11),  INT8_C(  85), -INT8_C(  85), -INT8_C(  35),  INT8_C(   9), -INT8_C(  49),  INT8_C(  26) },
        {  INT8_C(  18),  INT8_C(  93), -INT8_C(  21),  INT8_C(  20),  INT8_C(  96),  INT8_C(  53),  INT8_C(  93),  INT8_C(  34),
           INT8_C(   0), -INT8_C(  47), -INT8_C(   1), -INT8_C(   5),  INT8_C(  98),  INT8_C( 117), -INT8_C(  25), -INT8_C(  29) },
        { -INT8_C(   1),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),
           INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1) },
        { -INT8_C( 127),  INT8_C(  93), -INT8_C(  21),  INT8_C(  54), -INT8_C(  33),  INT8_C(  53),  INT8_C(  93),  INT8_C( 109),
           INT8_C(   0), -INT8_C(  47), -INT8_C(   1), -INT8_C(   5), -INT8_C(  35),  INT8_C( 117), -INT8_C(  25),  INT8_C(  26) } },
      { { -INT8_C( 123),  INT8_C(  51), -INT8_C(  86), -INT8_C(  27),  INT8_C( 104),  INT8_C(   8),  INT8_C(   7),  INT8_C( 105),
          -INT8_C(  39),  INT8_C(   6),  INT8_C( 100),  INT8_C(  59),  INT8_C( 123),  INT8_C(  75),  INT8_C(  31),  INT8_C(  85) },
        { -INT8_C(  61),  INT8_C(  57),  INT8_C(  14), -INT8_C(  78),  INT8_C( 126),  INT8_C(  52),  INT8_C(  96), -INT8_C(  49),
          -INT8_C(  80), -INT8_C(  71), -INT8_C(   4),  INT8_C(  52), -INT8_C(  31),  INT8_C(  68), -INT8_C(  53),  INT8_C( 102) },
        {  INT8_C(   0),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),
           INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1) },
        { -INT8_C(  61),  INT8_C(  57),  INT8_C(  14), -INT8_C(  27),  INT8_C( 126),  INT8_C(  52),  INT8_C(  96), -INT8_C(  49),
          -INT8_C(  80),  INT8_C(   6),  INT8_C( 100),  INT8_C(  59),  INT8_C( 123),  INT8_C(  75), -INT8_C(  53),  INT8_C(  85) } },
      { { -INT8_C(  22),  INT8_C(  55),  INT8_C( 110),  INT8_C( 104),  INT8_C( 107), -INT8_C(  50),  INT8_C(  55),  INT8_C(  27),
          -INT8_C( 121),  INT8_C(  52),  INT8_C(  80),  INT8_C( 104),  INT8_C( 120),  INT8_C(  27), -INT8_C(  50), -INT8_C(  16) },
        { -INT8_C( 112),  INT8_C(  25), -INT8_C(  48),  INT8_C(  14),  INT8_C( 107),  INT8_C(  25),  INT8_C( 100), -INT8_C(  61),
          -INT8_C(  58), -INT8_C(  10), -INT8_C( 105), -INT8_C(  66), -INT8_C(  89), -INT8_C(  64),  INT8_C( 122), -INT8_C( 111) },
        { -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),
           INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0) },
        { -INT8_C(  22),  INT8_C(  55),  INT8_C( 110),  INT8_C(  14),  INT8_C( 107),  INT8_C(  25),  INT8_C( 100), -INT8_C(  61),
          -INT8_C(  58),  INT8_C(  52),  INT8_C(  80),  INT8_C( 104),  INT8_C( 120), -INT8_C(  64), -INT8_C(  50), -INT8_C( 111) } },
      { { -INT8_C( 116), -INT8_C(  98), -INT8_C( 120), -INT8_C(   9), -INT8_C(  73), -INT8_C(  20), -INT8_C(  70),  INT8_C( 125),
          -INT8_C(  29),  INT8_C(  82),  INT8_C(  59), -INT8_C( 118),  INT8_C(  18), -INT8_C(  75),  INT8_C(  28),  INT8_C(  10) },
        { -INT8_C(  99),  INT8_C(  22),  INT8_C( 109),  INT8_C(  83),  INT8_C(  71), -INT8_C(  21), -INT8_C( 112), -INT8_C(  83),
          -INT8_C(  70),  INT8_C(  53), -INT8_C( 117), -INT8_C(  93), -INT8_C(  88),  INT8_C(  89),  INT8_C(  29),  INT8_C(  52) },
        { -INT8_C(   1), -INT8_C(   1),  INT8_C(   0), -INT8_C(   1), -INT8_C(   1), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0),
           INT8_C(   0),  INT8_C(   0), -INT8_C(   1),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0),  INT8_C(   0), -INT8_C(   1) },
        { -INT8_C( 116), -INT8_C(  98),  INT8_C( 109), -INT8_C(   9), -INT8_C(  73), -INT8_C(  20), -INT8_C( 112), -INT8_C(  83),
          -INT8_C(  70),  INT8_C(  53),  INT8_C(  59), -INT8_C(  93), -INT8_C(  88),  INT8_C(  89),  INT8_C(  29),  INT8_C(  10) } },
    };

    for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
      simde_v128_t a = simde_wasm_v128_load(test_vec[i].a);
      simde_v128_t b = simde_wasm_v128_load(test_vec[i].b);
      simde_v128_t mask = simde_wasm_v128_load(test_vec[i].mask);
      simde_v128_t r = simde_wasm_i8x16_relaxed_laneselect(a, b, mask);
      simde_test_wasm_i8x16_assert_equal(r, simde_wasm_v128_load(test_vec[i].r));
    }
    return 0;
  #else
    fputc('\n', stdout);
    for (int i = 0 ; i < 8 ; i++) {
      simde_v128_t
        a = simde_test_wasm_i8x16_random(),
        b = simde_test_wasm_i8x16_random(),
        mask = simde_wasm_i8x16_shr(simde_test_wasm_i8x16_random(), 7),
        r;

      r = simde_wasm_i8x16_relaxed_laneselect(a, b, mask);

      simde_test_wasm_i8x16_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
      simde_test_wasm_i8x16_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i8x16_write(3, mask, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i8x16_write(3, r, SIMDE_TEST_VEC_POS_LAST);
    }
    return 1;
  #endif
}

static int
test_simde_wasm_i16x8_relaxed_laneselect(SIMDE_MUNIT_TEST_ARGS) {
  #if 1
    SIMDE_TEST_STRUCT_MODIFIERS struct {
      int16_t a[sizeof(simde_v128_t) / sizeof(int16_t)];
      int16_t b[sizeof(simde_v128_t) / sizeof(int16_t)];
      int16_t mask[sizeof(simde_v128_t) / sizeof(int16_t)];
      int16_t r[sizeof(simde_v128_t) / sizeof(int16_t)];
    } test_vec[] = {
      { {  INT16_C( 32134), -INT16_C( 14619), -INT16_C( 12998),  INT16_C( 16363),  INT16_C( 31700), -INT16_C(  5370), -INT16_C( 15572), -INT16_C( 29959) },
        {  INT16_C( 31938),  INT16_C( 30682), -INT16_C( 21172), -INT16_C(  2301),  INT16_C(   762),  INT16_C( 22561), -INT16_C( 11973), -INT16_C( 16115) },
        { -INT16_C(     1), -INT16_C(     1),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0),  INT16_C(     0),  INT16_C(     0) },
        {  INT16_C( 32134), -INT16_C( 14619), -INT16_C( 21172),  INT16_C( 16363),  INT16_C( 31700),  INT16_C( 22561), -INT16_C( 11973), -INT16_C( 16115) } },
      { {  INT16_C( 32501),  INT16_C( 16842), -INT16_C( 13012),  INT16_C(  9784),  INT16_C( 23248),  INT16_C(  2942), -INT16_C( 29909),  INT16_C( 31436) },
        {  INT16_C( 21374),  INT16_C( 15875), -INT16_C( 13370), -INT16_C( 18990),  INT16_C( 21145),  INT16_C( 10959),  INT16_C( 29899), -INT16_C( 16002) },
        {  INT16_C(     0),  INT16_C(     0),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1) },
        {  INT16_C( 21374),  INT16_C( 15875), -INT16_C( 13370),  INT16_C(  9784),  INT16_C( 23248),  INT16_C(  2942), -INT16_C( 29909),  INT16_C( 31436) } },
      { {  INT16_C( 15632), -INT16_C( 10486), -INT16_C(  8952), -INT16_C( 24180),  INT16_C( 23343), -INT16_C(  1076),  INT16_C( 19151), -INT16_C( 15684) },
        { -INT16_C( 16750), -INT16_C( 22304),  INT16_C(  9721), -INT16_C( 29042),  INT16_C( 32744),  INT16_C( 13903), -INT16_C( 30404),  INT16_C( 19715) },
        {  INT16_C(     0), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0) },
        { -INT16_C( 16750), -INT16_C( 10486), -INT16_C(  8952), -INT16_C( 29042),  INT16_C( 32744), -INT16_C(  1076),  INT16_C( 19151),  INT16_C( 19715) } },
      { {  INT16_C( 32143), -INT16_C( 30270),  INT16_C( 20642), -INT16_C( 30185),  INT16_C( 26320),  INT16_C(  3265), -INT16_C( 15120), -INT16_C( 18599) },
        {  INT16_C( 32209), -INT16_C( 17274), -INT16_C(  2259),  INT16_C( 14806), -INT16_C(  5324), -INT16_C( 17644), -INT16_C( 20036),  INT16_C( 19413) },
        { -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0),  INT16_C(     0),  INT16_C(     0), -INT16_C(     1) },
        {  INT16_C( 32143), -INT16_C( 30270),  INT16_C( 20642), -INT16_C( 30185), -INT16_C(  5324), -INT16_C( 17644), -INT16_C( 20036), -INT16_C( 18599) } },
      { { -INT16_C( 32613), -INT16_C( 14226),  INT16_C( 17527), -INT16_C( 21503),  INT16_C(  5423), -INT16_C(  5273),  INT16_C( 15558), -INT16_C(  2762) },
        {  INT16_C(  3027), -INT16_C( 17466),  INT16_C(  8695),  INT16_C( 18802),  INT16_C( 13886),  INT16_C(  7820), -INT16_C( 31404), -INT16_C(  4144) },
        {  INT16_C(     0),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1) },
        {  INT16_C(  3027), -INT16_C( 17466),  INT16_C( 17527), -INT16_C( 21503),  INT16_C(  5423), -INT16_C(  5273),  INT16_C( 15558), -INT16_C(  2762) } },
      { {  INT16_C( 20702), -INT16_C( 10917), -INT16_C( 12687), -INT16_C( 20706), -INT16_C( 22012),  INT16_C( 22734), -INT16_C( 25040),  INT16_C( 13639) },
        { -INT16_C(    35),  INT16_C( 24498), -INT16_C(  9288), -INT16_C( 31215), -INT16_C( 21140),  INT16_C( 14619), -INT16_C( 23168),  INT16_C( 24281) },
        {  INT16_C(     0),  INT16_C(     0),  INT16_C(     0),  INT16_C(     0), -INT16_C(     1),  INT16_C(     0), -INT16_C(     1),  INT16_C(     0) },
        { -INT16_C(    35),  INT16_C( 24498), -INT16_C(  9288), -INT16_C( 31215), -INT16_C( 22012),  INT16_C( 14619), -INT16_C( 25040),  INT16_C( 24281) } },
      { {  INT16_C(  5286),  INT16_C( 24255), -INT16_C( 12048),  INT16_C( 23781),  INT16_C(   126), -INT16_C(   363),  INT16_C( 28326), -INT16_C( 25763) },
        { -INT16_C( 28509), -INT16_C( 23038),  INT16_C(  6626), -INT16_C(  8274),  INT16_C(  3837), -INT16_C( 32757),  INT16_C( 28085),  INT16_C( 23776) },
        { -INT16_C(     1),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0),  INT16_C(     0),  INT16_C(     0),  INT16_C(     0) },
        {  INT16_C(  5286), -INT16_C( 23038), -INT16_C( 12048),  INT16_C( 23781),  INT16_C(  3837), -INT16_C( 32757),  INT16_C( 28085),  INT16_C( 23776) } },
      { { -INT16_C(  6950), -INT16_C( 17125), -INT16_C( 13827), -INT16_C(  1380), -INT16_C( 22569), -INT16_C( 29317),  INT16_C( 23317), -INT16_C( 26647) },
        { -INT16_C( 23557),  INT16_C( 27657), -INT16_C( 10429), -INT16_C(  7334),  INT16_C( 18234),  INT16_C(  2857),  INT16_C(  2705),  INT16_C( 27776) },
        { -INT16_C(     1), -INT16_C(     1), -INT16_C(     1),  INT16_C(     0),  INT16_C(     0), -INT16_C(     1), -INT16_C(     1), -INT16_C(     1) },
        { -INT16_C(  6950), -INT16_C( 17125), -INT16_C( 13827), -INT16_C(  7334),  INT16_C( 18234), -INT16_C( 29317),  INT16_C( 23317), -INT16_C( 26647) } },
    };

    for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
      simde_v128_t a = simde_wasm_v128_load(test_vec[i].a);
      simde_v128_t b = simde_wasm_v128_load(test_vec[i].b);
      simde_v128_t mask = simde_wasm_v128_load(test_vec[i].mask);
      simde_v128_t r = simde_wasm_i16x8_relaxed_laneselect(a, b, mask);
      simde_test_wasm_i16x8_assert_equal(r, simde_wasm_v128_load(test_vec[i].r));
    }
    return 0;
  #else
    fputc('\n', stdout);
    for (int i = 0 ; i < 8 ; i++) {
      simde_v128_t
        a = simde_test_wasm_i16x8_random(),
        b = simde_test_wasm_i16x8_random(),
        mask = simde_wasm_i16x8_shr(simde_test_wasm_i16x8_random(), 15),
        r;

      r = simde_wasm_i16x8_relaxed_laneselect(a, b, mask);

      simde_test_wasm_i16x8_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
      simde_test_wasm_i16x8_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i16x8_write(3, mask, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i16x8_write(3, r, SIMDE_TEST_VEC_POS_LAST);
    }
    return 1;
  #endif
}

static int
test_simde_wasm_i32x4_relaxed_laneselect(SIMDE_MUNIT_TEST_ARGS) {
  #if 1
    SIMDE_TEST_STRUCT_MODIFIERS struct {
      int32_t a[sizeof(simde_v128_t) / sizeof(int32_t)];
      int32_t b[sizeof(simde_v128_t) / sizeof(int32_t)];
      int32_t mask[sizeof(simde_v128_t) / sizeof(int32_t)];
      int32_t r[sizeof(simde_v128_t) / sizeof(int32_t)];
    } test_vec[] = {
      { { -INT32_C(   550903393),  INT32_C(   915823364), -INT32_C(  1353539952),  INT32_C(  1660758645) },
        {  INT32_C(  1657433796), -INT32_C(   417913372), -INT32_C(   522906996),  INT32_C(  1171144101) },
        {  INT32_C(           0), -INT32_C(           1), -INT32_C(           1), -INT32_C(           1) },
        {  INT32_C(  1657433796),  INT32_C(   915823364), -INT32_C(  1353539952),  INT32_C(  1660758645) } },
      { { -INT32_C(   503514115), -INT32_C(  1396174048), -INT32_C(   879976922), -INT32_C(    99591461) },
        { -INT32_C(  1541655214),  INT32_C(  1233614320), -INT32_C(   149415647), -INT32_C(  1500427864) },
        {  INT32_C(           0), -INT32_C(           1), -INT32_C(           1),  INT32_C(           0) },
        { -INT32_C(  1541655214), -INT32_C(  1396174048), -INT32_C(   879976922), -INT32_C(  1500427864) } },
      { { -INT32_C(   923868968),  INT32_C(  1980855637),  INT32_C(   913123726), -INT32_C(  1227030926) },
        {  INT32_C(   756704396), -INT32_C(  1561056332), -INT32_C(  1083472184),  INT32_C(    17379113) },
        {  INT32_C(           0), -INT32_C(           1),  INT32_C(           0), -INT32_C(           1) },
        {  INT32_C(   756704396),  INT32_C(  1980855637), -INT32_C(  1083472184), -INT32_C(  1227030926) } },
      { {  INT32_C(   620775537),  INT32_C(  1002959987), -INT32_C(  1527106950),  INT32_C(  1889862497) },
        {  INT32_C(  1725263866),  INT32_C(  1314959434),  INT32_C(  1069912568),  INT32_C(   252900254) },
        { -INT32_C(           1), -INT32_C(           1), -INT32_C(           1), -INT32_C(           1) },
        {  INT32_C(   620775537),  INT32_C(  1002959987), -INT32_C(  1527106950),  INT32_C(  1889862497) } },
      { { -INT32_C(  2092379079),  INT32_C(  2110957700), -INT32_C(   675506375), -INT32_C(   974729334) },
        { -INT32_C(   395109663),  INT32_C(  1130978325),  INT32_C(   668110400), -INT32_C(  1844915880) },
        {  INT32_C(           0),  INT32_C(           0),  INT32_C(           0),  INT32_C(           0) },
        { -INT32_C(   395109663),  INT32_C(  1130978325),  INT32_C(   668110400), -INT32_C(  1844915880) } },
      { {  INT32_C(   553402891), -INT32_C(   547134049),  INT32_C(  1275475443), -INT32_C(  1377956345) },
        {  INT32_C(  1490547551),  INT32_C(  1519026139),  INT32_C(   375624931), -INT32_C(  1876282747) },
        {  INT32_C(           0), -INT32_C(           1),  INT32_C(           0),  INT32_C(           0) },
        {  INT32_C(  1490547551), -INT32_C(   547134049),  INT32_C(   375624931), -INT32_C(  1876282747) } },
      { {  INT32_C(  2025772445),  INT32_C(   936528212),  INT32_C(  1649227485), -INT32_C(   571312280) },
        {  INT32_C(   737256350),  INT32_C(    11265207), -INT32_C(   447645731), -INT32_C(  1102361055) },
        {  INT32_C(           0),  INT32_C(           0), -INT32_C(           1),  INT32_C(           0) },
        {  INT32_C(   737256350),  INT32_C(    11265207),  INT32_C(  1649227485), -INT32_C(  1102361055) } },
      { { -INT32_C(   549685464),  INT32_C(   971040603),  INT32_C(  2132685150), -INT32_C(  1556190849) },
        { -INT32_C(   971344525), -INT32_C(  1091057282),  INT32_C(   929467076),  INT32_C(   944368399) },
        { -INT32_C(           1), -INT32_C(           1), -INT32_C(           1), -INT32_C(           1) },
        { -INT32_C(   549685464),  INT32_C(   971040603),  INT32_C(  2132685150), -INT32_C(  1556190849) } },
    };

    for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
      simde_v128_t a = simde_wasm_v128_load(test_vec[i].a);
      simde_v128_t b = simde_wasm_v128_load(test_vec[i].b);
      simde_v128_t mask = simde_wasm_v128_load(test_vec[i].mask);
      simde_v128_t r = simde_wasm_i32x4_relaxed_laneselect(a, b, mask);
      simde_test_wasm_i32x4_assert_equal(r, simde_wasm_v128_load(test_vec[i].r));
    }
    return 0;
  #else
    fputc('\n', stdout);
    for (int i = 0 ; i < 8 ; i++) {
      simde_v128_t
        a = simde_test_wasm_i32x4_random(),
        b = simde_test_wasm_i32x4_random(),
        mask = simde_wasm_i32x4_shr(simde_test_wasm_i32x4_random(), 31),
        r;

      r = simde_wasm_i32x4_relaxed_laneselect(a, b, mask);

      simde_test_wasm_i32x4_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
      simde_test_wasm_i32x4_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i32x4_write(3, mask, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i32x4_write(3, r, SIMDE_TEST_VEC_POS_LAST);
    }
    return 1;
  #endif
}

static int
test_simde_wasm_i64x2_relaxed_laneselect(SIMDE_MUNIT_TEST_ARGS) {
  #if 1
    SIMDE_TEST_STRUCT_MODIFIERS struct {
      int64_t a[sizeof(simde_v128_t) / sizeof(int64_t)];
      int64_t b[sizeof(simde_v128_t) / sizeof(int64_t)];
      int64_t mask[sizeof(simde_v128_t) / sizeof(int64_t)];
      int64_t r[sizeof(simde_v128_t) / sizeof(int64_t)];
    } test_vec[] = {
      { { -INT64_C(  920230559648029186), -INT64_C( 1260599374326882247) },
        { -INT64_C( 5174174656278783751),  INT64_C(  227901295051177144) },
        { -INT64_C(                   1), -INT64_C(                   1) },
        { -INT64_C(  920230559648029186), -INT64_C( 1260599374326882247) } },
      { { -INT64_C( 2416918810298711507), -INT64_C( 7861527371947059491) },
        {  INT64_C( 8969767625585485343),  INT64_C( 5835319466009005665) },
        {  INT64_C(                   0),  INT64_C(                   0) },
        {  INT64_C( 8969767625585485343),  INT64_C( 5835319466009005665) } },
      { { -INT64_C( 6613997556779106663), -INT64_C( 8332271935948416534) },
        {  INT64_C( 5040138132682205949),  INT64_C(  810520879441068029) },
        {  INT64_C(                   0),  INT64_C(                   0) },
        {  INT64_C( 5040138132682205949),  INT64_C(  810520879441068029) } },
      { { -INT64_C( 8543658848418766532), -INT64_C( 1977126302010339822) },
        { -INT64_C( 1668121512941300234),  INT64_C( 6547745806153174316) },
        { -INT64_C(                   1),  INT64_C(                   0) },
        { -INT64_C( 8543658848418766532),  INT64_C( 6547745806153174316) } },
      { {  INT64_C( 4703844971547029517), -INT64_C( 9137620180819994697) },
        {  INT64_C( 2709879060874572645), -INT64_C( 8645716682788060227) },
        { -INT64_C(                   1), -INT64_C(                   1) },
        {  INT64_C( 4703844971547029517), -INT64_C( 9137620180819994697) } },
      { { -INT64_C(  199729314788289681), -INT64_C( 1859452044379490002) },
        {  INT64_C(  806334851516536955), -INT64_C( 1818383909588779911) },
        {  INT64_C(                   0),  INT64_C(                   0) },
        {  INT64_C(  806334851516536955), -INT64_C( 1818383909588779911) } },
      { {  INT64_C( 1977869283759027488), -INT64_C( 8293437078112952695) },
        {  INT64_C( 5010054574651597405), -INT64_C( 8803420830434632438) },
        { -INT64_C(                   1), -INT64_C(                   1) },
        {  INT64_C( 1977869283759027488), -INT64_C( 8293437078112952695) } },
      { { -INT64_C( 5337968786438725489),  INT64_C( 8863428825777084183) },
        { -INT64_C( 4203068692968641367), -INT64_C( 5930079492408315549) },
        { -INT64_C(                   1),  INT64_C(                   0) },
        { -INT64_C( 5337968786438725489), -INT64_C( 5930079492408315549) } },
    };

    for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) {
      simde_v128_t a = simde_wasm_v128_load(test_vec[i].a);
      simde_v128_t b = simde_wasm_v128_load(test_vec[i].b);
      simde_v128_t mask = simde_wasm_v128_load(test_vec[i].mask);
      simde_v128_t r = simde_wasm_i64x2_relaxed_laneselect(a, b, mask);
      simde_test_wasm_i64x2_assert_equal(r, simde_wasm_v128_load(test_vec[i].r));
    }
    return 0;
  #else
    fputc('\n', stdout);
    for (int i = 0 ; i < 8 ; i++) {
      simde_v128_t
        a = simde_test_wasm_i64x2_random(),
        b = simde_test_wasm_i64x2_random(),
        mask = simde_wasm_i64x2_shr(simde_test_wasm_i64x2_random(), 63),
        r;

      r = simde_wasm_i64x2_relaxed_laneselect(a, b, mask);

      simde_test_wasm_i64x2_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
      simde_test_wasm_i64x2_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i64x2_write(3, mask, SIMDE_TEST_VEC_POS_MIDDLE);
      simde_test_wasm_i64x2_write(3, r, SIMDE_TEST_VEC_POS_LAST);
    }
    return 1;
  #endif
}

SIMDE_TEST_FUNC_LIST_BEGIN
  SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i8x16_relaxed_laneselect)
  SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i16x8_relaxed_laneselect)
  SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i32x4_relaxed_laneselect)
  SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i64x2_relaxed_laneselect)
SIMDE_TEST_FUNC_LIST_END

#include "test-relaxed-simd-footer.h"