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
|
/* 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_SIMD128_INSN add_sat
#include "../../../simde/wasm/simd128.h"
#include "test-simd128.h"
static int
test_simde_wasm_i8x16_add_sat(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 r[sizeof(simde_v128_t) / sizeof(int8_t)];
} test_vec[] = {
{ { INT8_C( 67), INT8_C( 12), INT8_C( 47), -INT8_C( 90), -INT8_C( 17), INT8_C( 66), INT8_C( 109), INT8_C( 119),
INT8_C( 53), -INT8_C( 61), INT8_C( 2), INT8_C( 84), -INT8_C( 2), INT8_C( 53), INT8_C( 34), INT8_C( 57) },
{ -INT8_C( 4), INT8_C( 126), -INT8_C( 98), -INT8_C( 65), INT8_C( 33), -INT8_C( 68), INT8_MAX, INT8_C( 126),
INT8_C( 82), -INT8_C( 48), INT8_C( 51), -INT8_C( 110), INT8_MAX, INT8_C( 34), -INT8_C( 97), INT8_C( 39) },
{ INT8_C( 63), INT8_MAX, -INT8_C( 51), INT8_MIN, INT8_C( 16), -INT8_C( 2), INT8_MAX, INT8_MAX,
INT8_MAX, -INT8_C( 109), INT8_C( 53), -INT8_C( 26), INT8_C( 125), INT8_C( 87), -INT8_C( 63), INT8_C( 96) } },
{ { -INT8_C( 81), INT8_C( 17), -INT8_C( 26), -INT8_C( 74), -INT8_C( 117), -INT8_C( 113), INT8_C( 79), INT8_C( 4),
-INT8_C( 34), INT8_C( 98), -INT8_C( 88), INT8_C( 77), INT8_C( 8), -INT8_C( 114), -INT8_C( 125), -INT8_C( 22) },
{ -INT8_C( 123), INT8_C( 29), -INT8_C( 94), INT8_C( 27), -INT8_C( 27), INT8_C( 4), -INT8_C( 91), INT8_C( 86),
-INT8_C( 96), -INT8_C( 35), -INT8_C( 92), -INT8_C( 100), -INT8_C( 75), -INT8_C( 102), INT8_C( 98), INT8_C( 66) },
{ INT8_MIN, INT8_C( 46), -INT8_C( 120), -INT8_C( 47), INT8_MIN, -INT8_C( 109), -INT8_C( 12), INT8_C( 90),
INT8_MIN, INT8_C( 63), INT8_MIN, -INT8_C( 23), -INT8_C( 67), INT8_MIN, -INT8_C( 27), INT8_C( 44) } },
{ { INT8_C( 63), INT8_C( 31), INT8_C( 100), -INT8_C( 40), -INT8_C( 76), -INT8_C( 106), INT8_C( 2), -INT8_C( 59),
INT8_C( 69), INT8_C( 78), -INT8_C( 49), -INT8_C( 26), -INT8_C( 34), -INT8_C( 31), -INT8_C( 98), -INT8_C( 53) },
{ INT8_C( 75), INT8_C( 8), -INT8_C( 21), INT8_C( 8), -INT8_C( 55), -INT8_C( 2), INT8_C( 2), INT8_C( 67),
INT8_C( 28), INT8_C( 48), INT8_C( 84), INT8_C( 1), -INT8_C( 127), INT8_C( 106), INT8_C( 96), -INT8_C( 35) },
{ INT8_MAX, INT8_C( 39), INT8_C( 79), -INT8_C( 32), INT8_MIN, -INT8_C( 108), INT8_C( 4), INT8_C( 8),
INT8_C( 97), INT8_C( 126), INT8_C( 35), -INT8_C( 25), INT8_MIN, INT8_C( 75), -INT8_C( 2), -INT8_C( 88) } },
{ { -INT8_C( 100), INT8_C( 82), -INT8_C( 112), INT8_C( 72), -INT8_C( 25), -INT8_C( 22), INT8_C( 76), INT8_C( 96),
INT8_C( 107), -INT8_C( 72), -INT8_C( 4), -INT8_C( 109), -INT8_C( 126), INT8_C( 7), -INT8_C( 21), -INT8_C( 120) },
{ -INT8_C( 59), INT8_C( 105), INT8_C( 101), INT8_C( 3), INT8_C( 12), -INT8_C( 25), -INT8_C( 98), INT8_C( 37),
-INT8_C( 74), INT8_C( 56), -INT8_C( 75), INT8_C( 52), INT8_C( 98), -INT8_C( 93), -INT8_C( 67), INT8_C( 46) },
{ INT8_MIN, INT8_MAX, -INT8_C( 11), INT8_C( 75), -INT8_C( 13), -INT8_C( 47), -INT8_C( 22), INT8_MAX,
INT8_C( 33), -INT8_C( 16), -INT8_C( 79), -INT8_C( 57), -INT8_C( 28), -INT8_C( 86), -INT8_C( 88), -INT8_C( 74) } },
{ { -INT8_C( 34), -INT8_C( 33), -INT8_C( 112), INT8_C( 68), -INT8_C( 24), -INT8_C( 16), INT8_C( 114), INT8_C( 77),
-INT8_C( 99), INT8_C( 5), INT8_C( 23), -INT8_C( 56), -INT8_C( 52), -INT8_C( 2), INT8_C( 17), INT8_C( 62) },
{ -INT8_C( 81), -INT8_C( 16), INT8_C( 85), -INT8_C( 127), -INT8_C( 19), INT8_C( 53), -INT8_C( 78), INT8_C( 95),
-INT8_C( 73), INT8_C( 120), INT8_C( 93), -INT8_C( 103), -INT8_C( 107), INT8_C( 87), INT8_C( 45), -INT8_C( 125) },
{ -INT8_C( 115), -INT8_C( 49), -INT8_C( 27), -INT8_C( 59), -INT8_C( 43), INT8_C( 37), INT8_C( 36), INT8_MAX,
INT8_MIN, INT8_C( 125), INT8_C( 116), INT8_MIN, INT8_MIN, INT8_C( 85), INT8_C( 62), -INT8_C( 63) } },
{ { -INT8_C( 97), -INT8_C( 46), INT8_C( 92), -INT8_C( 29), -INT8_C( 110), -INT8_C( 119), INT8_C( 4), INT8_C( 30),
-INT8_C( 13), INT8_C( 112), INT8_C( 86), -INT8_C( 77), -INT8_C( 104), INT8_MAX, INT8_C( 13), -INT8_C( 94) },
{ -INT8_C( 22), INT8_C( 86), -INT8_C( 86), -INT8_C( 114), INT8_C( 52), INT8_C( 3), INT8_C( 50), -INT8_C( 29),
INT8_C( 1), -INT8_C( 22), -INT8_C( 61), -INT8_C( 9), -INT8_C( 1), -INT8_C( 27), -INT8_C( 34), INT8_C( 34) },
{ -INT8_C( 119), INT8_C( 40), INT8_C( 6), INT8_MIN, -INT8_C( 58), -INT8_C( 116), INT8_C( 54), INT8_C( 1),
-INT8_C( 12), INT8_C( 90), INT8_C( 25), -INT8_C( 86), -INT8_C( 105), INT8_C( 100), -INT8_C( 21), -INT8_C( 60) } },
{ { -INT8_C( 101), INT8_C( 81), -INT8_C( 47), INT8_C( 105), INT8_C( 30), INT8_C( 71), INT8_C( 29), INT8_C( 70),
INT8_C( 69), INT8_C( 37), -INT8_C( 71), INT8_C( 115), INT8_C( 110), INT8_C( 6), -INT8_C( 44), -INT8_C( 90) },
{ -INT8_C( 45), INT8_C( 90), -INT8_C( 44), -INT8_C( 34), INT8_C( 60), INT8_C( 3), -INT8_C( 48), -INT8_C( 74),
-INT8_C( 59), -INT8_C( 42), INT8_C( 107), INT8_C( 115), -INT8_C( 104), -INT8_C( 52), -INT8_C( 45), -INT8_C( 76) },
{ INT8_MIN, INT8_MAX, -INT8_C( 91), INT8_C( 71), INT8_C( 90), INT8_C( 74), -INT8_C( 19), -INT8_C( 4),
INT8_C( 10), -INT8_C( 5), INT8_C( 36), INT8_MAX, INT8_C( 6), -INT8_C( 46), -INT8_C( 89), INT8_MIN } },
{ { -INT8_C( 53), INT8_C( 85), INT8_C( 68), INT8_C( 32), -INT8_C( 19), INT8_C( 23), INT8_C( 35), INT8_C( 96),
-INT8_C( 85), -INT8_C( 28), -INT8_C( 10), -INT8_C( 48), -INT8_C( 78), INT8_C( 99), INT8_C( 114), -INT8_C( 92) },
{ INT8_C( 36), INT8_C( 67), INT8_C( 18), INT8_C( 103), -INT8_C( 126), -INT8_C( 21), INT8_C( 121), -INT8_C( 5),
-INT8_C( 64), INT8_C( 57), -INT8_C( 101), INT8_C( 3), INT8_C( 86), -INT8_C( 12), -INT8_C( 51), INT8_C( 43) },
{ -INT8_C( 17), INT8_MAX, INT8_C( 86), INT8_MAX, INT8_MIN, INT8_C( 2), INT8_MAX, INT8_C( 91),
INT8_MIN, INT8_C( 29), -INT8_C( 111), -INT8_C( 45), INT8_C( 8), INT8_C( 87), INT8_C( 63), -INT8_C( 49) } }
};
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 r = simde_wasm_i8x16_add_sat(a, b);
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(),
r;
r = simde_wasm_i8x16_add_sat(a, b);
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, r, SIMDE_TEST_VEC_POS_LAST);
}
return 1;
#endif
}
static int
test_simde_wasm_i16x8_add_sat(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 r[sizeof(simde_v128_t) / sizeof(int16_t)];
} test_vec[] = {
{ { -INT16_C( 4356), -INT16_C( 20330), INT16_C( 29657), -INT16_C( 3059), INT16_C( 7287), INT16_C( 28401), -INT16_C( 12985), INT16_C( 436) },
{ -INT16_C( 9912), INT16_C( 30539), INT16_C( 25772), INT16_C( 29791), -INT16_C( 24841), INT16_C( 27023), -INT16_C( 32102), INT16_C( 10667) },
{ -INT16_C( 14268), INT16_C( 10209), INT16_MAX, INT16_C( 26732), -INT16_C( 17554), INT16_MAX, INT16_MIN, INT16_C( 11103) } },
{ { INT16_C( 496), -INT16_C( 2876), INT16_C( 4600), -INT16_C( 15832), -INT16_C( 29266), -INT16_C( 30549), INT16_C( 27844), INT16_C( 21828) },
{ -INT16_C( 5319), INT16_C( 19801), INT16_C( 31510), -INT16_C( 29321), -INT16_C( 32530), -INT16_C( 22995), INT16_C( 9494), -INT16_C( 6323) },
{ -INT16_C( 4823), INT16_C( 16925), INT16_MAX, INT16_MIN, INT16_MIN, INT16_MIN, INT16_MAX, INT16_C( 15505) } },
{ { -INT16_C( 31503), INT16_C( 21247), INT16_C( 3822), -INT16_C( 31148), INT16_C( 26118), INT16_C( 9913), INT16_C( 26646), INT16_C( 4946) },
{ INT16_C( 18654), INT16_C( 11749), -INT16_C( 29476), -INT16_C( 7040), INT16_C( 10857), -INT16_C( 2509), -INT16_C( 6848), -INT16_C( 25351) },
{ -INT16_C( 12849), INT16_MAX, -INT16_C( 25654), INT16_MIN, INT16_MAX, INT16_C( 7404), INT16_C( 19798), -INT16_C( 20405) } },
{ { INT16_C( 16630), -INT16_C( 27846), -INT16_C( 23373), INT16_C( 16332), -INT16_C( 7331), -INT16_C( 11726), INT16_C( 32432), -INT16_C( 20303) },
{ INT16_C( 17375), -INT16_C( 1869), -INT16_C( 18585), INT16_C( 19843), INT16_C( 4772), INT16_C( 17136), INT16_C( 29747), INT16_C( 25403) },
{ INT16_MAX, -INT16_C( 29715), INT16_MIN, INT16_MAX, -INT16_C( 2559), INT16_C( 5410), INT16_MAX, INT16_C( 5100) } },
{ { INT16_C( 4148), INT16_C( 14400), INT16_C( 20962), -INT16_C( 1943), INT16_C( 28089), -INT16_C( 11480), INT16_C( 1846), INT16_C( 18561) },
{ -INT16_C( 20983), INT16_C( 17785), -INT16_C( 13962), INT16_C( 22998), -INT16_C( 17397), INT16_C( 6515), -INT16_C( 1756), -INT16_C( 23220) },
{ -INT16_C( 16835), INT16_C( 32185), INT16_C( 7000), INT16_C( 21055), INT16_C( 10692), -INT16_C( 4965), INT16_C( 90), -INT16_C( 4659) } },
{ { -INT16_C( 25023), INT16_C( 20548), -INT16_C( 28801), INT16_C( 2912), INT16_C( 15295), -INT16_C( 8044), -INT16_C( 29531), -INT16_C( 14005) },
{ INT16_C( 23328), -INT16_C( 3026), -INT16_C( 20825), INT16_C( 24737), INT16_C( 6010), INT16_C( 10303), INT16_C( 25157), -INT16_C( 527) },
{ -INT16_C( 1695), INT16_C( 17522), INT16_MIN, INT16_C( 27649), INT16_C( 21305), INT16_C( 2259), -INT16_C( 4374), -INT16_C( 14532) } },
{ { -INT16_C( 23126), -INT16_C( 10758), -INT16_C( 1975), -INT16_C( 4213), INT16_C( 27824), INT16_C( 22993), -INT16_C( 11008), -INT16_C( 27222) },
{ INT16_C( 7232), INT16_C( 18916), INT16_C( 24712), INT16_C( 2015), INT16_C( 24054), INT16_C( 12673), INT16_C( 13364), -INT16_C( 24607) },
{ -INT16_C( 15894), INT16_C( 8158), INT16_C( 22737), -INT16_C( 2198), INT16_MAX, INT16_MAX, INT16_C( 2356), INT16_MIN } },
{ { -INT16_C( 21745), INT16_C( 31266), INT16_C( 382), INT16_C( 30762), -INT16_C( 21278), -INT16_C( 888), INT16_C( 30075), -INT16_C( 21145) },
{ INT16_C( 16054), -INT16_C( 32238), INT16_C( 22044), INT16_C( 17380), INT16_C( 28904), INT16_C( 32701), -INT16_C( 10778), INT16_C( 17061) },
{ -INT16_C( 5691), -INT16_C( 972), INT16_C( 22426), INT16_MAX, INT16_C( 7626), INT16_C( 31813), INT16_C( 19297), -INT16_C( 4084) } }
};
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 r = simde_wasm_i16x8_add_sat(a, b);
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(),
r;
r = simde_wasm_i16x8_add_sat(a, b);
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, r, SIMDE_TEST_VEC_POS_LAST);
}
return 1;
#endif
}
static int
test_simde_wasm_u8x16_add_sat(SIMDE_MUNIT_TEST_ARGS) {
#if 1
SIMDE_TEST_STRUCT_MODIFIERS struct {
uint8_t a[sizeof(simde_v128_t) / sizeof(uint8_t)];
uint8_t b[sizeof(simde_v128_t) / sizeof(uint8_t)];
uint8_t r[sizeof(simde_v128_t) / sizeof(uint8_t)];
} test_vec[] = {
{ { UINT8_C(199), UINT8_C(179), UINT8_C( 47), UINT8_C(167), UINT8_C( 94), UINT8_C( 89), UINT8_C(119), UINT8_C( 74),
UINT8_C( 36), UINT8_C(244), UINT8_C( 16), UINT8_C( 40), UINT8_C( 63), UINT8_C(155), UINT8_C(180), UINT8_C(130) },
{ UINT8_C( 82), UINT8_C( 69), UINT8_C(236), UINT8_C( 98), UINT8_C( 47), UINT8_C( 55), UINT8_C(211), UINT8_C( 64),
UINT8_C(129), UINT8_C(153), UINT8_C(238), UINT8_C(238), UINT8_C( 97), UINT8_C(237), UINT8_C(238), UINT8_C( 40) },
{ UINT8_MAX, UINT8_C(248), UINT8_MAX, UINT8_MAX, UINT8_C(141), UINT8_C(144), UINT8_MAX, UINT8_C(138),
UINT8_C(165), UINT8_MAX, UINT8_C(254), UINT8_MAX, UINT8_C(160), UINT8_MAX, UINT8_MAX, UINT8_C(170) } },
{ { UINT8_C(140), UINT8_C( 32), UINT8_C( 86), UINT8_C(134), UINT8_C(196), UINT8_C(162), UINT8_C( 92), UINT8_C(169),
UINT8_C( 31), UINT8_C(127), UINT8_C(247), UINT8_C(247), UINT8_C( 75), UINT8_C(153), UINT8_C(122), UINT8_C(244) },
{ UINT8_C(247), UINT8_C(199), UINT8_C(170), UINT8_C( 69), UINT8_C(156), UINT8_C(139), UINT8_C(122), UINT8_C(102),
UINT8_C(187), UINT8_C(109), UINT8_C( 87), UINT8_C( 27), UINT8_C(207), UINT8_C( 72), UINT8_C(132), UINT8_C( 74) },
{ UINT8_MAX, UINT8_C(231), UINT8_MAX, UINT8_C(203), UINT8_MAX, UINT8_MAX, UINT8_C(214), UINT8_MAX,
UINT8_C(218), UINT8_C(236), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(225), UINT8_C(254), UINT8_MAX } },
{ { UINT8_C( 54), UINT8_C( 69), UINT8_C(173), UINT8_C(115), UINT8_C( 66), UINT8_C(103), UINT8_C(240), UINT8_C(231),
UINT8_C( 43), UINT8_C(142), UINT8_C(243), UINT8_C( 68), UINT8_C(227), UINT8_C(105), UINT8_C(166), UINT8_C(139) },
{ UINT8_C( 85), UINT8_C(210), UINT8_C(175), UINT8_C(226), UINT8_C(179), UINT8_C(155), UINT8_C( 49), UINT8_C( 58),
UINT8_C(136), UINT8_C( 97), UINT8_C( 97), UINT8_C(174), UINT8_C(169), UINT8_C(222), UINT8_C( 76), UINT8_C(124) },
{ UINT8_C(139), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(245), UINT8_MAX, UINT8_MAX, UINT8_MAX,
UINT8_C(179), UINT8_C(239), UINT8_MAX, UINT8_C(242), UINT8_MAX, UINT8_MAX, UINT8_C(242), UINT8_MAX } },
{ { UINT8_C( 65), UINT8_C(243), UINT8_C(201), UINT8_C(105), UINT8_C(107), UINT8_C( 78), UINT8_C( 56), UINT8_C(173),
UINT8_C( 92), UINT8_C(237), UINT8_C(188), UINT8_C(154), UINT8_C(211), UINT8_C(205), UINT8_C(100), UINT8_C( 3) },
{ UINT8_MAX, UINT8_C(157), UINT8_C(180), UINT8_C( 25), UINT8_C(120), UINT8_C( 17), UINT8_C(110), UINT8_C(125),
UINT8_C( 55), UINT8_C(172), UINT8_C(230), UINT8_C(231), UINT8_C(216), UINT8_C( 6), UINT8_C(210), UINT8_C(164) },
{ UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(130), UINT8_C(227), UINT8_C( 95), UINT8_C(166), UINT8_MAX,
UINT8_C(147), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(211), UINT8_MAX, UINT8_C(167) } },
{ { UINT8_C( 12), UINT8_C(207), UINT8_C(204), UINT8_C( 38), UINT8_C( 53), UINT8_C(231), UINT8_C( 10), UINT8_C( 14),
UINT8_C( 72), UINT8_C(188), UINT8_C(168), UINT8_C( 32), UINT8_C(127), UINT8_C(142), UINT8_C( 42), UINT8_C( 89) },
{ UINT8_C(131), UINT8_C( 49), UINT8_C(182), UINT8_C(243), UINT8_C( 9), UINT8_C( 49), UINT8_C(134), UINT8_C( 58),
UINT8_C( 99), UINT8_C(200), UINT8_C( 65), UINT8_C(119), UINT8_C( 64), UINT8_C(195), UINT8_C( 46), UINT8_C( 49) },
{ UINT8_C(143), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C( 62), UINT8_MAX, UINT8_C(144), UINT8_C( 72),
UINT8_C(171), UINT8_MAX, UINT8_C(233), UINT8_C(151), UINT8_C(191), UINT8_MAX, UINT8_C( 88), UINT8_C(138) } },
{ { UINT8_C(106), UINT8_C( 44), UINT8_C( 46), UINT8_C(218), UINT8_C(199), UINT8_C(239), UINT8_C(137), UINT8_C( 37),
UINT8_C(254), UINT8_C( 45), UINT8_C(212), UINT8_C( 41), UINT8_MAX, UINT8_C(161), UINT8_C(150), UINT8_C( 66) },
{ UINT8_C(192), UINT8_MAX, UINT8_C(125), UINT8_C( 19), UINT8_C( 33), UINT8_C(226), UINT8_C(231), UINT8_C( 36),
UINT8_C(169), UINT8_C(231), UINT8_C( 59), UINT8_C(213), UINT8_C(155), UINT8_C(165), UINT8_C(154), UINT8_C( 96) },
{ UINT8_MAX, UINT8_MAX, UINT8_C(171), UINT8_C(237), UINT8_C(232), UINT8_MAX, UINT8_MAX, UINT8_C( 73),
UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(254), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(162) } },
{ { UINT8_C(186), UINT8_C( 93), UINT8_C( 13), UINT8_C( 88), UINT8_C(178), UINT8_C( 21), UINT8_C( 29), UINT8_C( 51),
UINT8_C(118), UINT8_C(177), UINT8_C(204), UINT8_C( 65), UINT8_C(204), UINT8_C(204), UINT8_C(199), UINT8_C( 47) },
{ UINT8_C(184), UINT8_C(246), UINT8_C(173), UINT8_C(168), UINT8_C( 28), UINT8_C( 50), UINT8_C(213), UINT8_C(116),
UINT8_C(217), UINT8_C(236), UINT8_C(115), UINT8_C( 7), UINT8_C(227), UINT8_C( 50), UINT8_C(147), UINT8_C(247) },
{ UINT8_MAX, UINT8_MAX, UINT8_C(186), UINT8_MAX, UINT8_C(206), UINT8_C( 71), UINT8_C(242), UINT8_C(167),
UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C( 72), UINT8_MAX, UINT8_C(254), UINT8_MAX, UINT8_MAX } },
{ { UINT8_C(116), UINT8_C(145), UINT8_C(243), UINT8_C(197), UINT8_C(187), UINT8_C( 72), UINT8_C(244), UINT8_C( 64),
UINT8_C(131), UINT8_C(186), UINT8_C(189), UINT8_C(186), UINT8_C(215), UINT8_C(207), UINT8_C( 59), UINT8_C(204) },
{ UINT8_C(226), UINT8_C( 25), UINT8_C( 74), UINT8_C(215), UINT8_C(118), UINT8_C( 95), UINT8_C(165), UINT8_C( 71),
UINT8_C(170), UINT8_C(226), UINT8_C( 73), UINT8_C(242), UINT8_C( 47), UINT8_C(206), UINT8_C(108), UINT8_C(133) },
{ UINT8_MAX, UINT8_C(170), UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(167), UINT8_MAX, UINT8_C(135),
UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_MAX, UINT8_C(167), UINT8_MAX } }
};
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 r = simde_wasm_u8x16_add_sat(a, b);
simde_test_wasm_u8x16_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_u8x16_random(),
b = simde_test_wasm_u8x16_random(),
r;
r = simde_wasm_u8x16_add_sat(a, b);
simde_test_wasm_u8x16_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
simde_test_wasm_u8x16_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
simde_test_wasm_u8x16_write(3, r, SIMDE_TEST_VEC_POS_LAST);
}
return 1;
#endif
}
static int
test_simde_wasm_u16x8_add_sat(SIMDE_MUNIT_TEST_ARGS) {
#if 1
SIMDE_TEST_STRUCT_MODIFIERS struct {
uint16_t a[sizeof(simde_v128_t) / sizeof(uint16_t)];
uint16_t b[sizeof(simde_v128_t) / sizeof(uint16_t)];
uint16_t r[sizeof(simde_v128_t) / sizeof(uint16_t)];
} test_vec[] = {
{ { UINT16_C(10563), UINT16_C(49955), UINT16_C(30234), UINT16_C(14582), UINT16_C(59724), UINT16_C(49945), UINT16_C( 2616), UINT16_C(64807) },
{ UINT16_C(39420), UINT16_C(44746), UINT16_C(23509), UINT16_C(32883), UINT16_C(61675), UINT16_C(11596), UINT16_C( 8219), UINT16_C( 8819) },
{ UINT16_C(49983), UINT16_MAX, UINT16_C(53743), UINT16_C(47465), UINT16_MAX, UINT16_C(61541), UINT16_C(10835), UINT16_MAX } },
{ { UINT16_C(35473), UINT16_C(10341), UINT16_C(55872), UINT16_C(35910), UINT16_C(51767), UINT16_C(61380), UINT16_C(42566), UINT16_C(23379) },
{ UINT16_C(26978), UINT16_C(37273), UINT16_C(55429), UINT16_C( 9316), UINT16_C(54327), UINT16_C(19748), UINT16_C(64423), UINT16_C(44418) },
{ UINT16_C(62451), UINT16_C(47614), UINT16_MAX, UINT16_C(45226), UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_MAX } },
{ { UINT16_C(31645), UINT16_C( 8784), UINT16_C(48663), UINT16_C(20026), UINT16_C( 2401), UINT16_C(17858), UINT16_C(14659), UINT16_C(14965) },
{ UINT16_C(23007), UINT16_C(10794), UINT16_C(52096), UINT16_C(15967), UINT16_C(55083), UINT16_C(45817), UINT16_C(49822), UINT16_C(35362) },
{ UINT16_C(54652), UINT16_C(19578), UINT16_MAX, UINT16_C(35993), UINT16_C(57484), UINT16_C(63675), UINT16_C(64481), UINT16_C(50327) } },
{ { UINT16_C(63505), UINT16_C(61972), UINT16_C(50119), UINT16_C(54740), UINT16_C(11153), UINT16_C(54623), UINT16_C(61050), UINT16_C( 8462) },
{ UINT16_C(42748), UINT16_C(55167), UINT16_C(30188), UINT16_C(13635), UINT16_C(17683), UINT16_C(55909), UINT16_C(21363), UINT16_C(58145) },
{ UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_C(28836), UINT16_MAX, UINT16_MAX, UINT16_MAX } },
{ { UINT16_C(35086), UINT16_C( 4294), UINT16_C(43768), UINT16_C(55234), UINT16_C(49576), UINT16_C(49371), UINT16_C(12259), UINT16_C(52160) },
{ UINT16_C( 6874), UINT16_C(39732), UINT16_C(59429), UINT16_C(46504), UINT16_C(25892), UINT16_C(12505), UINT16_C(27818), UINT16_C(26542) },
{ UINT16_C(41960), UINT16_C(44026), UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_C(61876), UINT16_C(40077), UINT16_MAX } },
{ { UINT16_C( 7623), UINT16_C(58158), UINT16_C(39575), UINT16_C( 2519), UINT16_C( 9623), UINT16_C(51603), UINT16_C(51013), UINT16_C(43567) },
{ UINT16_C(39808), UINT16_C(35339), UINT16_C( 4152), UINT16_C( 2073), UINT16_C(60967), UINT16_C(21899), UINT16_C(37050), UINT16_C(34807) },
{ UINT16_C(47431), UINT16_MAX, UINT16_C(43727), UINT16_C( 4592), UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_MAX } },
{ { UINT16_C(22925), UINT16_C(59658), UINT16_C(58646), UINT16_C(16385), UINT16_C(43985), UINT16_C(26800), UINT16_C(36061), UINT16_C(57176) },
{ UINT16_C(18352), UINT16_C(47606), UINT16_C(15085), UINT16_C(62668), UINT16_C( 436), UINT16_C(63456), UINT16_C(29292), UINT16_C(13887) },
{ UINT16_C(41277), UINT16_MAX, UINT16_MAX, UINT16_MAX, UINT16_C(44421), UINT16_MAX, UINT16_C(65353), UINT16_MAX } },
{ { UINT16_C(30568), UINT16_C(27619), UINT16_C(21297), UINT16_C( 4302), UINT16_C(23357), UINT16_C(21327), UINT16_C(34684), UINT16_C(49005) },
{ UINT16_C( 2362), UINT16_C(44963), UINT16_C( 6213), UINT16_C( 8673), UINT16_C(40415), UINT16_C( 7000), UINT16_C(55747), UINT16_C(10878) },
{ UINT16_C(32930), UINT16_MAX, UINT16_C(27510), UINT16_C(12975), UINT16_C(63772), UINT16_C(28327), UINT16_MAX, UINT16_C(59883) } }
};
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 r = simde_wasm_u16x8_add_sat(a, b);
simde_test_wasm_u16x8_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_u16x8_random(),
b = simde_test_wasm_u16x8_random(),
r;
r = simde_wasm_u16x8_add_sat(a, b);
simde_test_wasm_u16x8_write(3, a, SIMDE_TEST_VEC_POS_FIRST);
simde_test_wasm_u16x8_write(3, b, SIMDE_TEST_VEC_POS_MIDDLE);
simde_test_wasm_u16x8_write(3, r, SIMDE_TEST_VEC_POS_LAST);
}
return 1;
#endif
}
SIMDE_TEST_FUNC_LIST_BEGIN
SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i8x16_add_sat)
SIMDE_TEST_FUNC_LIST_ENTRY(wasm_i16x8_add_sat)
SIMDE_TEST_FUNC_LIST_ENTRY(wasm_u8x16_add_sat)
SIMDE_TEST_FUNC_LIST_ENTRY(wasm_u16x8_add_sat)
SIMDE_TEST_FUNC_LIST_END
#include "test-simd128-footer.h"
|