static void TEST (void) { union128i_uw u, s1, s2; unsigned short e[8]; int i; s1.x = _mm_set_epi16 (10,20,30,90,80,40,100,15); s2.x = _mm_set_epi16 (11, 98, 76, 100, 34, 78, 39, 14); u.x = test (s1.x, s2.x); for (i = 0; i < 8; i++) e[i] = (s1.a[i] + s2.a[i]+1)>>1; if (check_union128i_uw (u, e)) abort (); }
static void TEST (void) { union128i_uw u, s1, s2; unsigned short e[8]; int i, tmp; s1.x = _mm_set_epi16 (10,2067,3033,90,80,40,1000,15); s2.x = _mm_set_epi16 (11, 9834, 7444, 10222, 34, 7833, 39, 14); u.x = test (s1.x, s2.x); for (i = 0; i < 8; i++) { tmp = s1.a[i] * s2.a[i]; e[i] = (tmp & 0xffff0000)>>16; } if (check_union128i_uw (u, e)) abort (); }