本文整理汇总了C++中MASK_ZERO函数的典型用法代码示例。如果您正苦于以下问题:C++ MASK_ZERO函数的具体用法?C++ MASK_ZERO怎么用?C++ MASK_ZERO使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了MASK_ZERO函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: TEST
void
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, i_w) res1, res2, res3;
UNION_TYPE (128, i_w) src;
MASK_TYPE mask = SIZE | 123;
short res_ref[SIZE];
sign = -1;
for (i = 0; i < 8; i++)
{
src.a[i] = 1 + 3 * i * sign;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
CALC (res_ref, src.a);
if (AVX512F_LEN == 512)
{
res1.x = INTRINSIC (_broadcastw_epi16) (src.x);
if (UNION_CHECK (AVX512F_LEN, i_w) (res1, res_ref))
abort ();
}
res2.x = INTRINSIC (_mask_broadcastw_epi16) (res2.x, mask, src.x);
res3.x = INTRINSIC (_maskz_broadcastw_epi16) (mask, src.x);
MASK_MERGE (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res2, res_ref))
abort ();
MASK_ZERO (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res3, res_ref))
abort ();
CALC (res_ref, src.a);
if (AVX512F_LEN == 512)
{
res1.x = INTRINSIC (_set1_epi16) (src.a[0]);
if (UNION_CHECK (AVX512F_LEN, i_w) (res1, res_ref))
abort ();
}
res2.x = INTRINSIC (_mask_set1_epi16) (res2.x, mask, src.a[0]);
res3.x = INTRINSIC (_maskz_set1_epi16) (mask, src.a[0]);
MASK_MERGE (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res2, res_ref))
abort ();
MASK_ZERO (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res3, res_ref))
abort ();
}
示例2: TEST
void
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, i_d) res1, res2, res3, src1;
MASK_TYPE mask = MASK_VALUE;
int res_ref[SIZE];
sign = -1;
for (i = 0; i < SIZE; i++)
{
src1.a[i] = 2 + sign * 7 * i % 291;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_srai_epi32) (src1.x, 3);
res2.x =
INTRINSIC (_mask_srai_epi32) (res2.x, mask, src1.x, 3);
res3.x = INTRINSIC (_maskz_srai_epi32) (mask, src1.x, 3);
CALC (res_ref, src1.a, 3);
if (UNION_CHECK (AVX512F_LEN, i_d) (res1, res_ref))
abort ();
MASK_MERGE (i_d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (res2, res_ref))
abort ();
MASK_ZERO (i_d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (res3, res_ref))
abort ();
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_srai_epi32) (src1.x, 33);
res2.x =
INTRINSIC (_mask_srai_epi32) (res2.x, mask, src1.x, 33);
res3.x = INTRINSIC (_maskz_srai_epi32) (mask, src1.x, 33);
CALC (res_ref, src1.a, 33);
if (UNION_CHECK (AVX512F_LEN, i_d) (res1, res_ref))
abort ();
MASK_MERGE (i_d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (res2, res_ref))
abort ();
MASK_ZERO (i_d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (res3, res_ref))
abort ();
}
示例3: TEST
void
TEST (void)
{
int i;
UNION_TYPE (AVX512F_LEN, i_uq) res1, res2, res3, src1;
MASK_TYPE mask = MASK_VALUE;
unsigned long long res_ref[SIZE];
for (i = 0; i < SIZE; i++)
{
src1.a[i] = 2 + 7 * i % 291;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_srli_epi64) (src1.x, 3);
res2.x =
INTRINSIC (_mask_srli_epi64) (res2.x, mask, src1.x, 3);
res3.x = INTRINSIC (_maskz_srli_epi64) (mask, src1.x, 3);
CALC (res_ref, src1.a, 3);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res1, res_ref))
abort ();
MASK_MERGE (i_uq) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res2, res_ref))
abort ();
MASK_ZERO (i_uq) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res3, res_ref))
abort ();
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_srli_epi64) (src1.x, 65);
res2.x =
INTRINSIC (_mask_srli_epi64) (res2.x, mask, src1.x, 65);
res3.x = INTRINSIC (_maskz_srli_epi64) (mask, src1.x, 65);
CALC (res_ref, src1.a, 65);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res1, res_ref))
abort ();
MASK_MERGE (i_uq) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res2, res_ref))
abort ();
MASK_ZERO (i_uq) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_uq) (res3, res_ref))
abort ();
}
示例4: TEST
void static
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, i_q) res1, res2, res3;
UNION_TYPE (128, i_q) src;
MASK_TYPE mask = MASK_VALUE;
long long res_ref[SIZE];
sign = -1;
for (i = 0; i < 2; i++)
{
src.a[i] = 1 + 34 * i * sign;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_broadcastq_epi64) (src.x);
res2.x = INTRINSIC (_mask_broadcastq_epi64) (res2.x, mask, src.x);
res3.x = INTRINSIC (_maskz_broadcastq_epi64) (mask, src.x);
CALC (res_ref, src.a);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
res1.x = INTRINSIC (_set1_epi64) (src.a[0]);
res2.x = INTRINSIC (_mask_set1_epi64) (res2.x, mask, src.a[0]);
res3.x = INTRINSIC (_maskz_set1_epi64) (mask, src.a[0]);
CALC (res_ref, src.a);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
}
示例5: avx512f_test
void
avx512f_test (void)
{
int i, sign;
union128 res1, res2, res3, res4, res5, src1, src2;
MASK_TYPE mask = MASK_VALUE;
float res_ref[SIZE];
sign = -1;
for (i = 0; i < SIZE; i++)
{
src1.a[i] = 1.5 + 34.67 * i * sign;
src2.a[i] = -22.17 * i * sign + 1.0;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
{
res1.a[i] = DEFAULT_VALUE;
res4.a[i] = DEFAULT_VALUE;
}
res1.x = _mm_mask_add_ss (res1.x, mask, src1.x, src2.x);
res2.x = _mm_maskz_add_ss (mask, src1.x, src2.x);
res3.x = _mm_add_round_ss (src1.x, src2.x, _MM_FROUND_NO_EXC);
res4.x = _mm_mask_add_round_ss (res4.x, mask, src1.x, src2.x, _MM_FROUND_NO_EXC);
res5.x = _mm_maskz_add_round_ss (mask, src1.x, src2.x, _MM_FROUND_NO_EXC);
calc_add (res_ref, src1.a, src2.a);
MASK_MERGE () (res_ref, mask, 1);
if (check_union128 (res1, res_ref))
abort ();
MASK_ZERO () (res_ref, mask, 1);
if (check_union128 (res2, res_ref))
abort ();
calc_add (res_ref, src1.a, src2.a);
if (check_union128 (res3, res_ref))
abort();
MASK_MERGE () (res_ref, mask, 1);
if (check_union128 (res4, res_ref))
abort ();
MASK_ZERO () (res_ref, mask, 1);
if (check_union128 (res5, res_ref))
abort ();
}
示例6: TEST
void
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, i_b) res1, res2, res3, src1, src2;
MASK_TYPE mask = MASK_VALUE;
char res_ref[SIZE];
sign = -1;
for (i = 0; i < SIZE; i++)
{
src1.a[i] = 34 * i * sign;
src1.a[i] = 179 * i;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_unpackhi_epi8) (src1.x, src2.x);
res2.x = INTRINSIC (_mask_unpackhi_epi8) (res2.x, mask, src1.x, src2.x);
res3.x = INTRINSIC (_maskz_unpackhi_epi8) (mask, src1.x, src2.x);
CALC (res_ref, src1.a, src2.a);
if (UNION_CHECK (AVX512F_LEN, i_b) (res1, res_ref))
abort ();
MASK_MERGE (i_b) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_b) (res2, res_ref))
abort ();
MASK_ZERO (i_b) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_b) (res3, res_ref))
abort ();
}
示例7: avx512er_test
void static
avx512er_test (void)
{
union512 src, res1, res2, res3;
__mmask16 mask = MASK_VALUE;
float res_ref[16];
int i;
for (i = 0; i < 16; i++)
{
src.a[i] = 179.345 - 6.5645 * i;
res2.a[i] = DEFAULT_VALUE;
}
res1.x = _mm512_exp2a23_ps (src.x);
res2.x = _mm512_mask_exp2a23_ps (res2.x, mask, src.x);
res3.x = _mm512_maskz_exp2a23_ps (mask, src.x);
compute_vexp2ps (src.a, res_ref);
if (check_rough_union512 (res1, res_ref, 0.0001))
abort ();
MASK_MERGE ()(res_ref, mask, 16);
if (check_rough_union512 (res2, res_ref, 0.0001))
abort ();
MASK_ZERO ()(res_ref, mask, 16);
if (check_rough_union512 (res3, res_ref, 0.0001))
abort ();
}
示例8: TEST
void
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, i_b) src1, src2, res1, res2, res3;
MASK_TYPE mask = MASK_VALUE;
char res_ref[SIZE];
for (i = 0; i < SIZE; i++)
{
src1.a[i] = i * sign;
src2.a[i] = (i + 20) * sign;
sign = -sign;
res2.a[i] = DEFAULT_VALUE;
}
res1.x = INTRINSIC (_min_epi8) (src1.x, src2.x);
res2.x = INTRINSIC (_mask_min_epi8) (res2.x, mask, src1.x, src2.x);
res3.x = INTRINSIC (_maskz_min_epi8) (mask, src1.x, src2.x);
CALC (src1.a, src2.a, res_ref);
if (UNION_CHECK (AVX512F_LEN, i_b) (res1, res_ref))
abort ();
MASK_MERGE (i_b) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_b) (res2, res_ref))
abort ();
MASK_ZERO (i_b) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_b) (res3, res_ref))
abort ();
}
示例9: TEST
static void
TEST (void)
{
UNION_TYPE (AVX512F_LEN, i_d) s1, s2;
UNION_TYPE (AVX512F_LEN, i_q) res1, res2, res3;
MASK_TYPE mask = MASK_VALUE;
unsigned long long res_ref[DST_SIZE];
int i, sign = 1;
for (i = 0; i < SRC_SIZE; i++)
{
s1.a[i] = i * 20;
s2.a[i] = i + 20;
}
for (i = 0; i < DST_SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
CALC (s1.a, s2.a, res_ref);
res1.x = INTRINSIC (_mul_epu32) (s1.x, s2.x);
res2.x = INTRINSIC (_mask_mul_epu32) (res2.x, mask, s1.x, s2.x);
res3.x = INTRINSIC (_maskz_mul_epu32) (mask, s1.x, s2.x);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, DST_SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, DST_SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
}
示例10: TEST
void
TEST (void)
{
int i;
UNION_TYPE (AVX512F_LEN, i_w) src1, src2, res1, res2, res3;
MASK_TYPE mask = MASK_VALUE;
unsigned short res_ref[SIZE];
for (i = 0; i < SIZE; i++)
{
src1.a[i] = i * i;
src2.a[i] = i + 20;
res2.a[i] = DEFAULT_VALUE;
}
res1.x = INTRINSIC (_min_epu16) (src1.x, src2.x);
res2.x = INTRINSIC (_mask_min_epu16) (res2.x, mask, src1.x, src2.x);
res3.x = INTRINSIC (_maskz_min_epu16) (mask, src1.x, src2.x);
CALC (src1.a, src2.a, res_ref);
if (UNION_CHECK (AVX512F_LEN, i_w) (res1, res_ref))
abort ();
MASK_MERGE (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res2, res_ref))
abort ();
MASK_ZERO (i_w) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_w) (res3, res_ref))
abort ();
}
示例11: TEST
void static
TEST (void)
{
UNION_TYPE (AVX512F_LEN, i_q) res1, res2, res3, s1, s2;
MASK_TYPE mask = MASK_VALUE;
long long res_ref[SIZE];
int i;
for (i = 0; i < SIZE; i++)
{
s1.a[i] = 2 * i;
s2.a[i] = i;
res2.a[i] = DEFAULT_VALUE;
}
res1.x = INTRINSIC (_alignr_epi64) (s1.x, s2.x, N);
res2.x = INTRINSIC (_mask_alignr_epi64) (res2.x, mask, s1.x, s2.x, N);
res3.x = INTRINSIC (_maskz_alignr_epi64) (mask, s1.x, s2.x, N);
CALC (s1.a, s2.a, res_ref);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
}
示例12: TEST
void
TEST (void)
{
union128i_w s;
UNION_TYPE (AVX512F_LEN, i_q) res1, res2, res3;
MASK_TYPE mask = MASK_VALUE;
long long int res_ref[SIZE];
int i, sign = 1;
for (i = 0; i < SIZE; i++)
{
s.a[i] = 2000 * i * sign;
res2.a[i] = DEFAULT_VALUE;
sign = -sign;
}
res1.x = INTRINSIC (_cvtepi16_epi64) (s.x);
res2.x = INTRINSIC (_mask_cvtepi16_epi64) (res2.x, mask, s.x);
res3.x = INTRINSIC (_maskz_cvtepi16_epi64) (mask, s.x);
CALC (s.a, res_ref);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
}
示例13: TEST
void
TEST (void)
{
int i, sign;
UNION_TYPE (AVX512F_LEN, d) res1, res2, res3;
UNION_TYPE (128, d) src;
MASK_TYPE mask = MASK_VALUE;
double res_ref[SIZE];
sign = -1;
for (i = 0; i < 2; i++)
{
src.a[i] = 1.5 + 34.67 * i * sign;
sign = sign * -1;
}
for (i = 0; i < SIZE; i++)
res2.a[i] = DEFAULT_VALUE;
res1.x = INTRINSIC (_broadcastsd_pd) (src.x);
res2.x = INTRINSIC (_mask_broadcastsd_pd) (res2.x, mask, src.x);
res3.x = INTRINSIC (_maskz_broadcastsd_pd) (mask, src.x);
CALC (res_ref, src.a);
if (UNION_CHECK (AVX512F_LEN, d) (res1, res_ref))
abort ();
MASK_MERGE (d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, d) (res2, res_ref))
abort ();
MASK_ZERO (d) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, d) (res3, res_ref))
abort ();
}
示例14: TEST
static void
TEST (void)
{
int ck[SIZE];
int i;
UNION_TYPE (AVX512F_LEN, i_d) s, d, dm, dz;
MASK_TYPE mask = MASK_VALUE;
for (i = 0; i < SIZE; i++)
{
s.a[i] = i * 7 + (i << 15) + 356;
d.a[i] = DEFAULT_VALUE;
dm.a[i] = DEFAULT_VALUE;
dz.a[i] = DEFAULT_VALUE;
}
CALC (s.a, ck);
d.x = INTRINSIC (_abs_epi32) (s.x);
dz.x = INTRINSIC (_maskz_abs_epi32) (mask, s.x);
dm.x = INTRINSIC (_mask_abs_epi32) (dm.x, mask, s.x);
if (UNION_CHECK (AVX512F_LEN, i_d) (d, ck))
abort ();
MASK_MERGE (i_d) (ck, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (dm, ck))
abort ();
MASK_ZERO (i_d) (ck, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_d) (dz, ck))
abort ();
}
示例15: TEST
void
TEST (void)
{
UNION_TYPE (AVX512F_LEN, d) s;
UNION_TYPE (AVX512F_LEN, i_q) res1, res2, res3;
MASK_TYPE mask = MASK_VALUE;
unsigned long long res_ref[SIZE];
int i;
for (i = 0; i < SIZE; i++)
{
s.a[i] = 123.456 * (i + 2000);
res2.a[i] = DEFAULT_VALUE;
}
res1.x = INTRINSIC (_cvttpd_epu64) (s.x);
res2.x = INTRINSIC (_mask_cvttpd_epu64) (res2.x, mask, s.x);
res3.x = INTRINSIC (_maskz_cvttpd_epu64) (mask, s.x);
CALC (s.a, res_ref);
if (UNION_CHECK (AVX512F_LEN, i_q) (res1, res_ref))
abort ();
MASK_MERGE (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res2, res_ref))
abort ();
MASK_ZERO (i_q) (res_ref, mask, SIZE);
if (UNION_CHECK (AVX512F_LEN, i_q) (res3, res_ref))
abort ();
}