VPTESTMW - Packed TEST Mask Word

VPTESTMW k1{k2}, xmm2, xmm3/m128    (V5+BW+VL
__mmask8 _mm_test_epi16_mask(__m128i a, __m128i b)
__mmask8 _mm_mask_test_epi16_mask(__mmask8 k2, __m128i a, __m128i b)

各WORDについてビット単位のAND演算を行い、立っているビットがあれば1を、そうでなければ0を③の対応するビットにセット
k2のビットが0の要素は処理されず③の対応するビットは0になる。③の上位ビットは0クリアされる。
VPTESTMW k1{k2}, ymm2, ymm3/m256    (V5+BW+VL
__mmask16 _mm256_test_epi16_mask(__m256i a, __m256i b)
__mmask16 _mm256_mask_test_epi16_mask(__mmask16 k2, __m256i a, __m256i b)

各WORDについてビット単位のAND演算を行い、立っているビットがあれば1を、そうでなければ0を③の対応するビットにセット
k2のビットが0の要素は処理されず③の対応するビットは0になる。③の上位ビットは0クリアされる。
VPTESTMW k1{k2}, zmm2, zmm3/m512    (V5+BW
__mmask32 _mm512_test_epi16_mask(__m512i a, __m512i b)
__mmask32 _mm512_mask_test_epi16_mask(__mmask32 k2, __m512i a, __m512i b)

各WORDについてビット単位のAND演算を行い、立っているビットがあれば1を、そうでなければ0を③の対応するビットにセット
k2のビットが0の要素は処理されず③の対応するビットは0になる。③の上位ビットは0クリアされる。

x86/x64 SIMD命令一覧表  フィードバック