comparison test/test_arith.h @ 7:945d410803f8

*: fix clang & gcc warnings, add avg test, etc
author Paper <paper@tflc.us>
date Wed, 23 Oct 2024 20:07:08 -0400
parents 75ab77f874e2
children d1d5d767004c
comparison
equal deleted inserted replaced
6:978c167dcceb 7:945d410803f8
38 vuint##bits##x##size##_store_aligned(b, orig_b); \ 38 vuint##bits##x##size##_store_aligned(b, orig_b); \
39 v##sign##int##bits##x##size##_store_aligned(c, orig_c); \ 39 v##sign##int##bits##x##size##_store_aligned(c, orig_c); \
40 \ 40 \
41 for (int i = 0; i < size; i++) { \ 41 for (int i = 0; i < size; i++) { \
42 if ((sign##int##bits##_t)(equiv) != orig_c[i]) { \ 42 if ((sign##int##bits##_t)(equiv) != orig_c[i]) { \
43 fprintf(stderr, "v" #sign "int" #bits "x" #size "_" #op " test FAILED at index %d: (" #equiv ") [%" PRI ## psign ## bits "] does not equal result [%" PRI ## psign ## bits "]!\n", i, equiv, orig_c[i]); \ 43 fprintf(stderr, "v" #sign "int" #bits "x" #size "_" #op " test FAILED at index %d: (" #equiv ") [%" PRI ## psign ## bits "] does not equal result [%" PRI ## psign ## bits "]!\n", i, (sign##int##bits##_t)(equiv), orig_c[i]); \
44 print_v##sign##int##bits##x##size(stderr,a); \ 44 print_v##sign##int##bits##x##size(stderr,a); \
45 print_vuint##bits##x##size(stderr,b); \ 45 print_vuint##bits##x##size(stderr,b); \
46 print_v##sign##int##bits##x##size(stderr,c); \ 46 print_v##sign##int##bits##x##size(stderr,c); \
47 fprintf(stderr, "\n"); \ 47 fprintf(stderr, "\n"); \
48 return 1; \ 48 return 1; \
58 CREATE_TEST(sign, psign, csign, bits, size, mul, orig_a[i] * orig_b[i]) \ 58 CREATE_TEST(sign, psign, csign, bits, size, mul, orig_a[i] * orig_b[i]) \
59 CREATE_TEST(sign, psign, csign, bits, size, div, (orig_b[i]) ? (orig_a[i] / orig_b[i]) : 0) \ 59 CREATE_TEST(sign, psign, csign, bits, size, div, (orig_b[i]) ? (orig_a[i] / orig_b[i]) : 0) \
60 CREATE_TEST(sign, psign, csign, bits, size, and, orig_a[i] & orig_b[i]) \ 60 CREATE_TEST(sign, psign, csign, bits, size, and, orig_a[i] & orig_b[i]) \
61 CREATE_TEST(sign, psign, csign, bits, size, or, orig_a[i] | orig_b[i]) \ 61 CREATE_TEST(sign, psign, csign, bits, size, or, orig_a[i] | orig_b[i]) \
62 CREATE_TEST(sign, psign, csign, bits, size, xor, orig_a[i] ^ orig_b[i]) \ 62 CREATE_TEST(sign, psign, csign, bits, size, xor, orig_a[i] ^ orig_b[i]) \
63 CREATE_TEST(sign, psign, csign, bits, size, avg, (orig_a[i] * orig_b[i]) / 2) \ 63 CREATE_TEST(sign, psign, csign, bits, size, avg, (sign##int##bits##_t)(orig_a[i] + orig_b[i]) / 2) \
64 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, rshift, vec_##sign##rshift(orig_a[i], orig_b[i])) \ 64 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, rshift, vec_##sign##rshift(orig_a[i], orig_b[i])) \
65 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lshift, vec_##sign##lshift(orig_a[i], orig_b[i])) \ 65 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lshift, vec_##sign##lshift(orig_a[i], orig_b[i])) \
66 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lrshift, vec_##sign##lrshift(orig_a[i], orig_b[i])) 66 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lrshift, vec_##sign##lrshift(orig_a[i], orig_b[i]))
67 67
68 #define CREATE_TESTS_2(bits, size) \ 68 #define CREATE_TESTS_2(bits, size) \
92 ret |= test_arith_v##sign##int##bits##x##size##_mul(a, b); \ 92 ret |= test_arith_v##sign##int##bits##x##size##_mul(a, b); \
93 ret |= test_arith_v##sign##int##bits##x##size##_div(a, b); \ 93 ret |= test_arith_v##sign##int##bits##x##size##_div(a, b); \
94 ret |= test_arith_v##sign##int##bits##x##size##_and(a, b); \ 94 ret |= test_arith_v##sign##int##bits##x##size##_and(a, b); \
95 ret |= test_arith_v##sign##int##bits##x##size##_or(a, b); \ 95 ret |= test_arith_v##sign##int##bits##x##size##_or(a, b); \
96 ret |= test_arith_v##sign##int##bits##x##size##_xor(a, b); \ 96 ret |= test_arith_v##sign##int##bits##x##size##_xor(a, b); \
97 ret |= test_arith_v##sign##int##bits##x##size##_avg(a, b); \
97 } \ 98 } \
98 } \ 99 } \
99 \ 100 \
100 for (size_t i = 0U; i < ARRAY_SIZE(testval##sign##bits); i++) { \ 101 for (size_t i = 0U; i < ARRAY_SIZE(testval##sign##bits); i++) { \
101 const v##sign##int##bits##x##size a = vtest##sign##bits##x##size(i); \ 102 const v##sign##int##bits##x##size a = vtest##sign##bits##x##size(i); \