CMPLTPS - CoMPare Less Than Packed Single
CMPLTPS xmm1, xmm2/m128 (S1
__m128 _mm_cmplt_ps(__m128 a, __m128 b)
① < ②のとき全ビット1を、それ以外のとき全ビット0を③の対応するfloatにセット
VCMPLTPS xmm1, xmm2, xmm3/m128 (V1
__m128 _mm_cmplt_ps(__m128 a, __m128 b)
① < ②のとき全ビット1を、それ以外のとき全ビット0を③の対応するfloatにセット
VCMPLTPS ymm1, ymm2, ymm3/m256 (V1
__m256 _mm256_cmp_ps(__m256 a, __m256 b, _CMP_LT_OS)
① < ②のとき全ビット1を、それ以外のとき全ビット0を③の対応するfloatにセット
VCMPLTPS k1{k2}, xmm2, xmm3/m128/m32bcst (V5+VL
__mmask8 _mm_cmp_ps_mask(__m128 a, __m128 b, _CMP_LT_OS)
__mmask8 _mm_mask_cmp_ps_mask(__mmask8 k2, __m128 a, __m128 b, _CMP_LT_OS)
① < ②のとき1を、それ以外のとき0を③の対応するビットにセット
k2のビットが0の要素は比較されず③の対応するビットは0になる。③の上位ビットは0クリアされる。
VCMPLTPS k1{k2}, ymm2, ymm3/m256/m32bcst (V5+VL
__mmask8 _mm256_cmp_ps_mask(__m256 a, __m256 b, _CMP_LT_OS)
__mmask8 _mm256_mask_cmp_ps_mask(__mmask8 k2, __m256 a, __m256 b, _CMP_LT_OS)
① < ②のとき1を、それ以外のとき0を③の対応するビットにセット
k2のビットが0の要素は比較されず③の対応するビットは0になる。③の上位ビットは0クリアされる。
VCMPLTPS k1{k2}, zmm2, zmm3/m512/m32bcst{sae} (V5
__mmask16 _mm512_cmp_ps_mask(__m512 a, __m512 b, _CMP_LT_OS)
__mmask16 _mm512_mask_cmp_ps_mask(__mmask16 k2, __m512 a, __m512 b, _CMP_LT_OS)
__mmask16 _mm512_cmp_round_ps_mask(__m512 a, __m512 b, _CMP_LT_OS, int sae)
__mmask16 _mm512_mask_cmp_round_ps_mask(__mmask16 k2, __m512 a, __m512 b, _CMP_LT_OS, int sae)
① < ②のとき1を、それ以外のとき0を③の対応するビットにセット
k2のビットが0の要素は比較されず③の対応するビットは0になる。③の上位ビットは0クリアされる。
この命令は:
Ordered - ソースオペランドのどちらかまたは両方がNaNのとき条件不成立
Signaling - QNaNで例外
CMPPS/VCMPPS命令で記述する場合のimm8値=1h
x86/x64 SIMD命令一覧表
フィードバック