Available on

**x86**only.## Expand description

Platform-specific intrinsics for the `x86`

platform.

See the module documentation for more details.

## Structs§

- Cpuid
Result x86 or x86-64 Result of the`cpuid`

instruction. - __m128
x86 or x86-64 128-bit wide set of four`f32`

types, x86-specific - __m256
x86 or x86-64 256-bit wide set of eight`f32`

types, x86-specific - __m512
x86 or x86-64 512-bit wide set of sixteen`f32`

types, x86-specific - __m128d
x86 or x86-64 128-bit wide set of two`f64`

types, x86-specific - __m128i
x86 or x86-64 128-bit wide integer vector type, x86-specific - __m256d
x86 or x86-64 256-bit wide set of four`f64`

types, x86-specific - __m256i
x86 or x86-64 256-bit wide integer vector type, x86-specific - __m512d
x86 or x86-64 512-bit wide set of eight`f64`

types, x86-specific - __m512i
x86 or x86-64 512-bit wide integer vector type, x86-specific - __
m128bh Experimental x86 or x86-64 128-bit wide set of eight`u16`

types, x86-specific - __m128h
Experimental x86 or x86-64 128-bit wide set of 8`f16`

types, x86-specific - __
m256bh Experimental x86 or x86-64 256-bit wide set of 16`u16`

types, x86-specific - __m256h
Experimental x86 or x86-64 256-bit wide set of 16`f16`

types, x86-specific - __
m512bh Experimental x86 or x86-64 512-bit wide set of 32`u16`

types, x86-specific - __m512h
Experimental x86 or x86-64 512-bit wide set of 32`f16`

types, x86-specific - bf16
Experimental x86 or x86-64 The BFloat16 type used in AVX-512 intrinsics.

## Constants§

- _CMP_
EQ_ OQ x86 or x86-64 Equal (ordered, non-signaling) - _CMP_
EQ_ OS x86 or x86-64 Equal (ordered, signaling) - _CMP_
EQ_ UQ x86 or x86-64 Equal (unordered, non-signaling) - _CMP_
EQ_ US x86 or x86-64 Equal (unordered, signaling) - _CMP_
FALSE_ OQ x86 or x86-64 False (ordered, non-signaling) - _CMP_
FALSE_ OS x86 or x86-64 False (ordered, signaling) - _CMP_
GE_ OQ x86 or x86-64 Greater-than-or-equal (ordered, non-signaling) - _CMP_
GE_ OS x86 or x86-64 Greater-than-or-equal (ordered, signaling) - _CMP_
GT_ OQ x86 or x86-64 Greater-than (ordered, non-signaling) - _CMP_
GT_ OS x86 or x86-64 Greater-than (ordered, signaling) - _CMP_
LE_ OQ x86 or x86-64 Less-than-or-equal (ordered, non-signaling) - _CMP_
LE_ OS x86 or x86-64 Less-than-or-equal (ordered, signaling) - _CMP_
LT_ OQ x86 or x86-64 Less-than (ordered, non-signaling) - _CMP_
LT_ OS x86 or x86-64 Less-than (ordered, signaling) - _CMP_
NEQ_ OQ x86 or x86-64 Not-equal (ordered, non-signaling) - _CMP_
NEQ_ OS x86 or x86-64 Not-equal (ordered, signaling) - _CMP_
NEQ_ UQ x86 or x86-64 Not-equal (unordered, non-signaling) - _CMP_
NEQ_ US x86 or x86-64 Not-equal (unordered, signaling) - _CMP_
NGE_ UQ x86 or x86-64 Not-greater-than-or-equal (unordered, non-signaling) - _CMP_
NGE_ US x86 or x86-64 Not-greater-than-or-equal (unordered, signaling) - _CMP_
NGT_ UQ x86 or x86-64 Not-greater-than (unordered, non-signaling) - _CMP_
NGT_ US x86 or x86-64 Not-greater-than (unordered, signaling) - _CMP_
NLE_ UQ x86 or x86-64 Not-less-than-or-equal (unordered, non-signaling) - _CMP_
NLE_ US x86 or x86-64 Not-less-than-or-equal (unordered, signaling) - _CMP_
NLT_ UQ x86 or x86-64 Not-less-than (unordered, non-signaling) - _CMP_
NLT_ US x86 or x86-64 Not-less-than (unordered, signaling) - _CMP_
ORD_ Q x86 or x86-64 Ordered (non-signaling) - _CMP_
ORD_ S x86 or x86-64 Ordered (signaling) - _CMP_
TRUE_ UQ x86 or x86-64 True (unordered, non-signaling) - _CMP_
TRUE_ US x86 or x86-64 True (unordered, signaling) - _CMP_
UNORD_ Q x86 or x86-64 Unordered (non-signaling) - _CMP_
UNORD_ S x86 or x86-64 Unordered (signaling) - _MM_
EXCEPT_ DENORM x86 or x86-64 See`_mm_setcsr`

- _MM_
EXCEPT_ DIV_ ZERO x86 or x86-64 See`_mm_setcsr`

- _MM_
EXCEPT_ INEXACT x86 or x86-64 See`_mm_setcsr`

- _MM_
EXCEPT_ INVALID x86 or x86-64 See`_mm_setcsr`

- _MM_
EXCEPT_ MASK x86 or x86-64 - _MM_
EXCEPT_ OVERFLOW x86 or x86-64 See`_mm_setcsr`

- _MM_
EXCEPT_ UNDERFLOW x86 or x86-64 See`_mm_setcsr`

- _MM_
FLUSH_ ZERO_ MASK x86 or x86-64 - _MM_
FLUSH_ ZERO_ OFF x86 or x86-64 See`_mm_setcsr`

- _MM_
FLUSH_ ZERO_ ON x86 or x86-64 See`_mm_setcsr`

- _MM_
FROUND_ CEIL x86 or x86-64 round up and do not suppress exceptions - _MM_
FROUND_ CUR_ DIRECTION x86 or x86-64 use MXCSR.RC; see`vendor::_MM_SET_ROUNDING_MODE`

- _MM_
FROUND_ FLOOR x86 or x86-64 round down and do not suppress exceptions - _MM_
FROUND_ NEARBYINT x86 or x86-64 use MXCSR.RC and suppress exceptions; see`vendor::_MM_SET_ROUNDING_MODE`

- _MM_
FROUND_ NINT x86 or x86-64 round to nearest and do not suppress exceptions - _MM_
FROUND_ NO_ EXC x86 or x86-64 suppress exceptions - _MM_
FROUND_ RAISE_ EXC x86 or x86-64 do not suppress exceptions - _MM_
FROUND_ RINT x86 or x86-64 use MXCSR.RC and do not suppress exceptions; see`vendor::_MM_SET_ROUNDING_MODE`

- _MM_
FROUND_ TO_ NEAREST_ INT x86 or x86-64 round to nearest - _MM_
FROUND_ TO_ NEG_ INF x86 or x86-64 round down - _MM_
FROUND_ TO_ POS_ INF x86 or x86-64 round up - _MM_
FROUND_ TO_ ZERO x86 or x86-64 truncate - _MM_
FROUND_ TRUNC x86 or x86-64 truncate and do not suppress exceptions - _MM_
HINT_ ET0 x86 or x86-64 See`_mm_prefetch`

. - _MM_
HINT_ ET1 x86 or x86-64 See`_mm_prefetch`

. - _MM_
HINT_ NTA x86 or x86-64 See`_mm_prefetch`

. - _MM_
HINT_ T0 x86 or x86-64 See`_mm_prefetch`

. - _MM_
HINT_ T1 x86 or x86-64 See`_mm_prefetch`

. - _MM_
HINT_ T2 x86 or x86-64 See`_mm_prefetch`

. - _MM_
MASK_ DENORM x86 or x86-64 See`_mm_setcsr`

- _MM_
MASK_ DIV_ ZERO x86 or x86-64 See`_mm_setcsr`

- _MM_
MASK_ INEXACT x86 or x86-64 See`_mm_setcsr`

- _MM_
MASK_ INVALID x86 or x86-64 See`_mm_setcsr`

- _MM_
MASK_ MASK x86 or x86-64 - _MM_
MASK_ OVERFLOW x86 or x86-64 See`_mm_setcsr`

- _MM_
MASK_ UNDERFLOW x86 or x86-64 See`_mm_setcsr`

- _MM_
ROUND_ DOWN x86 or x86-64 See`_mm_setcsr`

- _MM_
ROUND_ MASK x86 or x86-64 - _MM_
ROUND_ NEAREST x86 or x86-64 See`_mm_setcsr`

- _MM_
ROUND_ TOWARD_ ZERO x86 or x86-64 See`_mm_setcsr`

- _MM_
ROUND_ UP x86 or x86-64 See`_mm_setcsr`

- _SIDD_
BIT_ MASK x86 or x86-64 **Mask only**: return the bit mask - _SIDD_
CMP_ EQUAL_ ANY x86 or x86-64 For each character in`a`

, find if it is in`b`

*(Default)* - _SIDD_
CMP_ EQUAL_ EACH x86 or x86-64 The strings defined by`a`

and`b`

are equal - _SIDD_
CMP_ EQUAL_ ORDERED x86 or x86-64 Search for the defined substring in the target - _SIDD_
CMP_ RANGES x86 or x86-64 For each character in`a`

, determine if`b[0] <= c <= b[1] or b[1] <= c <= b[2]...`

- _SIDD_
LEAST_ SIGNIFICANT x86 or x86-64 **Index only**: return the least significant bit*(Default)* - _SIDD_
MASKED_ NEGATIVE_ POLARITY x86 or x86-64 Negates results only before the end of the string - _SIDD_
MASKED_ POSITIVE_ POLARITY x86 or x86-64 Do not negate results before the end of the string - _SIDD_
MOST_ SIGNIFICANT x86 or x86-64 **Index only**: return the most significant bit - _SIDD_
NEGATIVE_ POLARITY x86 or x86-64 Negates results - _SIDD_
POSITIVE_ POLARITY x86 or x86-64 Do not negate results*(Default)* - _SIDD_
SBYTE_ OPS x86 or x86-64 String contains signed 8-bit characters - _SIDD_
SWORD_ OPS x86 or x86-64 String contains unsigned 16-bit characters - _SIDD_
UBYTE_ OPS x86 or x86-64 String contains unsigned 8-bit characters*(Default)* - _SIDD_
UNIT_ MASK x86 or x86-64 **Mask only**: return the byte mask - _SIDD_
UWORD_ OPS x86 or x86-64 String contains unsigned 16-bit characters - _XCR_
XFEATURE_ ENABLED_ MASK x86 or x86-64 `XFEATURE_ENABLED_MASK`

for`XCR`

- _MM_
CMPINT_ EQ Experimental x86 or x86-64 Equal - _MM_
CMPINT_ FALSE Experimental x86 or x86-64 False - _MM_
CMPINT_ LE Experimental x86 or x86-64 Less-than-or-equal - _MM_
CMPINT_ LT Experimental x86 or x86-64 Less-than - _MM_
CMPINT_ NE Experimental x86 or x86-64 Not-equal - _MM_
CMPINT_ NLE Experimental x86 or x86-64 Not less-than-or-equal - _MM_
CMPINT_ NLT Experimental x86 or x86-64 Not less-than - _MM_
CMPINT_ TRUE Experimental x86 or x86-64 True - _MM_
MANT_ NORM_ 1_ 2 Experimental x86 or x86-64 interval [1, 2) - _MM_
MANT_ NORM_ P5_ 1 Experimental x86 or x86-64 interval [0.5, 1) - _MM_
MANT_ NORM_ P5_ 2 Experimental x86 or x86-64 interval [0.5, 2) - _MM_
MANT_ NORM_ P75_ 1P5 Experimental x86 or x86-64 interval [0.75, 1.5) - _MM_
MANT_ SIGN_ NAN Experimental x86 or x86-64 DEST = NaN if sign(SRC) = 1 - _MM_
MANT_ SIGN_ SRC Experimental x86 or x86-64 sign = sign(SRC) - _MM_
MANT_ SIGN_ ZERO Experimental x86 or x86-64 sign = 0 - _MM_
PERM_ AAAA Experimental x86 or x86-64 - _MM_
PERM_ AAAB Experimental x86 or x86-64 - _MM_
PERM_ AAAC Experimental x86 or x86-64 - _MM_
PERM_ AAAD Experimental x86 or x86-64 - _MM_
PERM_ AABA Experimental x86 or x86-64 - _MM_
PERM_ AABB Experimental x86 or x86-64 - _MM_
PERM_ AABC Experimental x86 or x86-64 - _MM_
PERM_ AABD Experimental x86 or x86-64 - _MM_
PERM_ AACA Experimental x86 or x86-64 - _MM_
PERM_ AACB Experimental x86 or x86-64 - _MM_
PERM_ AACC Experimental x86 or x86-64 - _MM_
PERM_ AACD Experimental x86 or x86-64 - _MM_
PERM_ AADA Experimental x86 or x86-64 - _MM_
PERM_ AADB Experimental x86 or x86-64 - _MM_
PERM_ AADC Experimental x86 or x86-64 - _MM_
PERM_ AADD Experimental x86 or x86-64 - _MM_
PERM_ ABAA Experimental x86 or x86-64 - _MM_
PERM_ ABAB Experimental x86 or x86-64 - _MM_
PERM_ ABAC Experimental x86 or x86-64 - _MM_
PERM_ ABAD Experimental x86 or x86-64 - _MM_
PERM_ ABBA Experimental x86 or x86-64 - _MM_
PERM_ ABBB Experimental x86 or x86-64 - _MM_
PERM_ ABBC Experimental x86 or x86-64 - _MM_
PERM_ ABBD Experimental x86 or x86-64 - _MM_
PERM_ ABCA Experimental x86 or x86-64 - _MM_
PERM_ ABCB Experimental x86 or x86-64 - _MM_
PERM_ ABCC Experimental x86 or x86-64 - _MM_
PERM_ ABCD Experimental x86 or x86-64 - _MM_
PERM_ ABDA Experimental x86 or x86-64 - _MM_
PERM_ ABDB Experimental x86 or x86-64 - _MM_
PERM_ ABDC Experimental x86 or x86-64 - _MM_
PERM_ ABDD Experimental x86 or x86-64 - _MM_
PERM_ ACAA Experimental x86 or x86-64 - _MM_
PERM_ ACAB Experimental x86 or x86-64 - _MM_
PERM_ ACAC Experimental x86 or x86-64 - _MM_
PERM_ ACAD Experimental x86 or x86-64 - _MM_
PERM_ ACBA Experimental x86 or x86-64 - _MM_
PERM_ ACBB Experimental x86 or x86-64 - _MM_
PERM_ ACBC Experimental x86 or x86-64 - _MM_
PERM_ ACBD Experimental x86 or x86-64 - _MM_
PERM_ ACCA Experimental x86 or x86-64 - _MM_
PERM_ ACCB Experimental x86 or x86-64 - _MM_
PERM_ ACCC Experimental x86 or x86-64 - _MM_
PERM_ ACCD Experimental x86 or x86-64 - _MM_
PERM_ ACDA Experimental x86 or x86-64 - _MM_
PERM_ ACDB Experimental x86 or x86-64 - _MM_
PERM_ ACDC Experimental x86 or x86-64 - _MM_
PERM_ ACDD Experimental x86 or x86-64 - _MM_
PERM_ ADAA Experimental x86 or x86-64 - _MM_
PERM_ ADAB Experimental x86 or x86-64 - _MM_
PERM_ ADAC Experimental x86 or x86-64 - _MM_
PERM_ ADAD Experimental x86 or x86-64 - _MM_
PERM_ ADBA Experimental x86 or x86-64 - _MM_
PERM_ ADBB Experimental x86 or x86-64 - _MM_
PERM_ ADBC Experimental x86 or x86-64 - _MM_
PERM_ ADBD Experimental x86 or x86-64 - _MM_
PERM_ ADCA Experimental x86 or x86-64 - _MM_
PERM_ ADCB Experimental x86 or x86-64 - _MM_
PERM_ ADCC Experimental x86 or x86-64 - _MM_
PERM_ ADCD Experimental x86 or x86-64 - _MM_
PERM_ ADDA Experimental x86 or x86-64 - _MM_
PERM_ ADDB Experimental x86 or x86-64 - _MM_
PERM_ ADDC Experimental x86 or x86-64 - _MM_
PERM_ ADDD Experimental x86 or x86-64 - _MM_
PERM_ BAAA Experimental x86 or x86-64 - _MM_
PERM_ BAAB Experimental x86 or x86-64 - _MM_
PERM_ BAAC Experimental x86 or x86-64 - _MM_
PERM_ BAAD Experimental x86 or x86-64 - _MM_
PERM_ BABA Experimental x86 or x86-64 - _MM_
PERM_ BABB Experimental x86 or x86-64 - _MM_
PERM_ BABC Experimental x86 or x86-64 - _MM_
PERM_ BABD Experimental x86 or x86-64 - _MM_
PERM_ BACA Experimental x86 or x86-64 - _MM_
PERM_ BACB Experimental x86 or x86-64 - _MM_
PERM_ BACC Experimental x86 or x86-64 - _MM_
PERM_ BACD Experimental x86 or x86-64 - _MM_
PERM_ BADA Experimental x86 or x86-64 - _MM_
PERM_ BADB Experimental x86 or x86-64 - _MM_
PERM_ BADC Experimental x86 or x86-64 - _MM_
PERM_ BADD Experimental x86 or x86-64 - _MM_
PERM_ BBAA Experimental x86 or x86-64 - _MM_
PERM_ BBAB Experimental x86 or x86-64 - _MM_
PERM_ BBAC Experimental x86 or x86-64 - _MM_
PERM_ BBAD Experimental x86 or x86-64 - _MM_
PERM_ BBBA Experimental x86 or x86-64 - _MM_
PERM_ BBBB Experimental x86 or x86-64 - _MM_
PERM_ BBBC Experimental x86 or x86-64 - _MM_
PERM_ BBBD Experimental x86 or x86-64 - _MM_
PERM_ BBCA Experimental x86 or x86-64 - _MM_
PERM_ BBCB Experimental x86 or x86-64 - _MM_
PERM_ BBCC Experimental x86 or x86-64 - _MM_
PERM_ BBCD Experimental x86 or x86-64 - _MM_
PERM_ BBDA Experimental x86 or x86-64 - _MM_
PERM_ BBDB Experimental x86 or x86-64 - _MM_
PERM_ BBDC Experimental x86 or x86-64 - _MM_
PERM_ BBDD Experimental x86 or x86-64 - _MM_
PERM_ BCAA Experimental x86 or x86-64 - _MM_
PERM_ BCAB Experimental x86 or x86-64 - _MM_
PERM_ BCAC Experimental x86 or x86-64 - _MM_
PERM_ BCAD Experimental x86 or x86-64 - _MM_
PERM_ BCBA Experimental x86 or x86-64 - _MM_
PERM_ BCBB Experimental x86 or x86-64 - _MM_
PERM_ BCBC Experimental x86 or x86-64 - _MM_
PERM_ BCBD Experimental x86 or x86-64 - _MM_
PERM_ BCCA Experimental x86 or x86-64 - _MM_
PERM_ BCCB Experimental x86 or x86-64 - _MM_
PERM_ BCCC Experimental x86 or x86-64 - _MM_
PERM_ BCCD Experimental x86 or x86-64 - _MM_
PERM_ BCDA Experimental x86 or x86-64 - _MM_
PERM_ BCDB Experimental x86 or x86-64 - _MM_
PERM_ BCDC Experimental x86 or x86-64 - _MM_
PERM_ BCDD Experimental x86 or x86-64 - _MM_
PERM_ BDAA Experimental x86 or x86-64 - _MM_
PERM_ BDAB Experimental x86 or x86-64 - _MM_
PERM_ BDAC Experimental x86 or x86-64 - _MM_
PERM_ BDAD Experimental x86 or x86-64 - _MM_
PERM_ BDBA Experimental x86 or x86-64 - _MM_
PERM_ BDBB Experimental x86 or x86-64 - _MM_
PERM_ BDBC Experimental x86 or x86-64 - _MM_
PERM_ BDBD Experimental x86 or x86-64 - _MM_
PERM_ BDCA Experimental x86 or x86-64 - _MM_
PERM_ BDCB Experimental x86 or x86-64 - _MM_
PERM_ BDCC Experimental x86 or x86-64 - _MM_
PERM_ BDCD Experimental x86 or x86-64 - _MM_
PERM_ BDDA Experimental x86 or x86-64 - _MM_
PERM_ BDDB Experimental x86 or x86-64 - _MM_
PERM_ BDDC Experimental x86 or x86-64 - _MM_
PERM_ BDDD Experimental x86 or x86-64 - _MM_
PERM_ CAAA Experimental x86 or x86-64 - _MM_
PERM_ CAAB Experimental x86 or x86-64 - _MM_
PERM_ CAAC Experimental x86 or x86-64 - _MM_
PERM_ CAAD Experimental x86 or x86-64 - _MM_
PERM_ CABA Experimental x86 or x86-64 - _MM_
PERM_ CABB Experimental x86 or x86-64 - _MM_
PERM_ CABC Experimental x86 or x86-64 - _MM_
PERM_ CABD Experimental x86 or x86-64 - _MM_
PERM_ CACA Experimental x86 or x86-64 - _MM_
PERM_ CACB Experimental x86 or x86-64 - _MM_
PERM_ CACC Experimental x86 or x86-64 - _MM_
PERM_ CACD Experimental x86 or x86-64 - _MM_
PERM_ CADA Experimental x86 or x86-64 - _MM_
PERM_ CADB Experimental x86 or x86-64 - _MM_
PERM_ CADC Experimental x86 or x86-64 - _MM_
PERM_ CADD Experimental x86 or x86-64 - _MM_
PERM_ CBAA Experimental x86 or x86-64 - _MM_
PERM_ CBAB Experimental x86 or x86-64 - _MM_
PERM_ CBAC Experimental x86 or x86-64 - _MM_
PERM_ CBAD Experimental x86 or x86-64 - _MM_
PERM_ CBBA Experimental x86 or x86-64 - _MM_
PERM_ CBBB Experimental x86 or x86-64 - _MM_
PERM_ CBBC Experimental x86 or x86-64 - _MM_
PERM_ CBBD Experimental x86 or x86-64 - _MM_
PERM_ CBCA Experimental x86 or x86-64 - _MM_
PERM_ CBCB Experimental x86 or x86-64 - _MM_
PERM_ CBCC Experimental x86 or x86-64 - _MM_
PERM_ CBCD Experimental x86 or x86-64 - _MM_
PERM_ CBDA Experimental x86 or x86-64 - _MM_
PERM_ CBDB Experimental x86 or x86-64 - _MM_
PERM_ CBDC Experimental x86 or x86-64 - _MM_
PERM_ CBDD Experimental x86 or x86-64 - _MM_
PERM_ CCAA Experimental x86 or x86-64 - _MM_
PERM_ CCAB Experimental x86 or x86-64 - _MM_
PERM_ CCAC Experimental x86 or x86-64 - _MM_
PERM_ CCAD Experimental x86 or x86-64 - _MM_
PERM_ CCBA Experimental x86 or x86-64 - _MM_
PERM_ CCBB Experimental x86 or x86-64 - _MM_
PERM_ CCBC Experimental x86 or x86-64 - _MM_
PERM_ CCBD Experimental x86 or x86-64 - _MM_
PERM_ CCCA Experimental x86 or x86-64 - _MM_
PERM_ CCCB Experimental x86 or x86-64 - _MM_
PERM_ CCCC Experimental x86 or x86-64 - _MM_
PERM_ CCCD Experimental x86 or x86-64 - _MM_
PERM_ CCDA Experimental x86 or x86-64 - _MM_
PERM_ CCDB Experimental x86 or x86-64 - _MM_
PERM_ CCDC Experimental x86 or x86-64 - _MM_
PERM_ CCDD Experimental x86 or x86-64 - _MM_
PERM_ CDAA Experimental x86 or x86-64 - _MM_
PERM_ CDAB Experimental x86 or x86-64 - _MM_
PERM_ CDAC Experimental x86 or x86-64 - _MM_
PERM_ CDAD Experimental x86 or x86-64 - _MM_
PERM_ CDBA Experimental x86 or x86-64 - _MM_
PERM_ CDBB Experimental x86 or x86-64 - _MM_
PERM_ CDBC Experimental x86 or x86-64 - _MM_
PERM_ CDBD Experimental x86 or x86-64 - _MM_
PERM_ CDCA Experimental x86 or x86-64 - _MM_
PERM_ CDCB Experimental x86 or x86-64 - _MM_
PERM_ CDCC Experimental x86 or x86-64 - _MM_
PERM_ CDCD Experimental x86 or x86-64 - _MM_
PERM_ CDDA Experimental x86 or x86-64 - _MM_
PERM_ CDDB Experimental x86 or x86-64 - _MM_
PERM_ CDDC Experimental x86 or x86-64 - _MM_
PERM_ CDDD Experimental x86 or x86-64 - _MM_
PERM_ DAAA Experimental x86 or x86-64 - _MM_
PERM_ DAAB Experimental x86 or x86-64 - _MM_
PERM_ DAAC Experimental x86 or x86-64 - _MM_
PERM_ DAAD Experimental x86 or x86-64 - _MM_
PERM_ DABA Experimental x86 or x86-64 - _MM_
PERM_ DABB Experimental x86 or x86-64 - _MM_
PERM_ DABC Experimental x86 or x86-64 - _MM_
PERM_ DABD Experimental x86 or x86-64 - _MM_
PERM_ DACA Experimental x86 or x86-64 - _MM_
PERM_ DACB Experimental x86 or x86-64 - _MM_
PERM_ DACC Experimental x86 or x86-64 - _MM_
PERM_ DACD Experimental x86 or x86-64 - _MM_
PERM_ DADA Experimental x86 or x86-64 - _MM_
PERM_ DADB Experimental x86 or x86-64 - _MM_
PERM_ DADC Experimental x86 or x86-64 - _MM_
PERM_ DADD Experimental x86 or x86-64 - _MM_
PERM_ DBAA Experimental x86 or x86-64 - _MM_
PERM_ DBAB Experimental x86 or x86-64 - _MM_
PERM_ DBAC Experimental x86 or x86-64 - _MM_
PERM_ DBAD Experimental x86 or x86-64 - _MM_
PERM_ DBBA Experimental x86 or x86-64 - _MM_
PERM_ DBBB Experimental x86 or x86-64 - _MM_
PERM_ DBBC Experimental x86 or x86-64 - _MM_
PERM_ DBBD Experimental x86 or x86-64 - _MM_
PERM_ DBCA Experimental x86 or x86-64 - _MM_
PERM_ DBCB Experimental x86 or x86-64 - _MM_
PERM_ DBCC Experimental x86 or x86-64 - _MM_
PERM_ DBCD Experimental x86 or x86-64 - _MM_
PERM_ DBDA Experimental x86 or x86-64 - _MM_
PERM_ DBDB Experimental x86 or x86-64 - _MM_
PERM_ DBDC Experimental x86 or x86-64 - _MM_
PERM_ DBDD Experimental x86 or x86-64 - _MM_
PERM_ DCAA Experimental x86 or x86-64 - _MM_
PERM_ DCAB Experimental x86 or x86-64 - _MM_
PERM_ DCAC Experimental x86 or x86-64 - _MM_
PERM_ DCAD Experimental x86 or x86-64 - _MM_
PERM_ DCBA Experimental x86 or x86-64 - _MM_
PERM_ DCBB Experimental x86 or x86-64 - _MM_
PERM_ DCBC Experimental x86 or x86-64 - _MM_
PERM_ DCBD Experimental x86 or x86-64 - _MM_
PERM_ DCCA Experimental x86 or x86-64 - _MM_
PERM_ DCCB Experimental x86 or x86-64 - _MM_
PERM_ DCCC Experimental x86 or x86-64 - _MM_
PERM_ DCCD Experimental x86 or x86-64 - _MM_
PERM_ DCDA Experimental x86 or x86-64 - _MM_
PERM_ DCDB Experimental x86 or x86-64 - _MM_
PERM_ DCDC Experimental x86 or x86-64 - _MM_
PERM_ DCDD Experimental x86 or x86-64 - _MM_
PERM_ DDAA Experimental x86 or x86-64 - _MM_
PERM_ DDAB Experimental x86 or x86-64 - _MM_
PERM_ DDAC Experimental x86 or x86-64 - _MM_
PERM_ DDAD Experimental x86 or x86-64 - _MM_
PERM_ DDBA Experimental x86 or x86-64 - _MM_
PERM_ DDBB Experimental x86 or x86-64 - _MM_
PERM_ DDBC Experimental x86 or x86-64 - _MM_
PERM_ DDBD Experimental x86 or x86-64 - _MM_
PERM_ DDCA Experimental x86 or x86-64 - _MM_
PERM_ DDCB Experimental x86 or x86-64 - _MM_
PERM_ DDCC Experimental x86 or x86-64 - _MM_
PERM_ DDCD Experimental x86 or x86-64 - _MM_
PERM_ DDDA Experimental x86 or x86-64 - _MM_
PERM_ DDDB Experimental x86 or x86-64 - _MM_
PERM_ DDDC Experimental x86 or x86-64 - _MM_
PERM_ DDDD Experimental x86 or x86-64 - _XABORT_
CAPACITY Experimental x86 or x86-64 Transaction abort due to the transaction using too much memory. - _XABORT_
CONFLICT Experimental x86 or x86-64 Transaction abort due to a memory conflict with another thread. - _XABORT_
DEBUG Experimental x86 or x86-64 Transaction abort due to a debug trap. - _XABORT_
EXPLICIT Experimental x86 or x86-64 Transaction explicitly aborted with xabort. The parameter passed to xabort is available with`_xabort_code(status)`

. - _XABORT_
NESTED Experimental x86 or x86-64 Transaction abort in a inner nested transaction. - _XABORT_
RETRY Experimental x86 or x86-64 Transaction retry is possible. - _XBEGIN_
STARTED Experimental x86 or x86-64 Transaction successfully started.

## Functions§

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- See
`_mm_setcsr`

- Transpose the 4x4 matrix formed by 4 rows of __m128 in place.
- See
`__cpuid_count`

. - Returns the result of the
`cpuid`

instruction for a given`leaf`

(`EAX`

) and`sub_leaf`

(`ECX`

). - Returns the highest-supported
`leaf`

(`EAX`

) and sub-leaf (`ECX`

)`cpuid`

values. - Reads the current value of the processor’s time-stamp counter and the
`IA32_TSC_AUX MSR`

. - Adds unsigned 32-bit integers
`a`

and`b`

with unsigned 8-bit carry-in`c_in`

(carry or overflow flag), and store the unsigned 32-bit result in`out`

, and the carry-out is returned (carry or overflow flag). - Adds unsigned 32-bit integers
`a`

and`b`

with unsigned 8-bit carry-in`c_in`

(carry or overflow flag), and store the unsigned 32-bit result in`out`

, and the carry-out is returned (carry or overflow flag). - Bitwise logical
`AND`

of inverted`a`

with`b`

. - Extracts bits of
`a`

specified by`control`

into the least significant bits of the result. - Extracts bits in range [
`start`

,`start`

+`length`

) from`a`

into the least significant bits of the result. - Extracts bits of
`a`

specified by`control`

into the least significant bits of the result. - Returns the bit in position
`b`

of the memory addressed by`p`

. - Returns the bit in position
`b`

of the memory addressed by`p`

, then inverts that bit. - Returns the bit in position
`b`

of the memory addressed by`p`

, then resets that bit to`0`

. - Returns the bit in position
`b`

of the memory addressed by`p`

, then sets the bit to`1`

. - Clears all bits below the least significant zero bit of
`x`

. - Sets all bits of
`x`

to 1 except for the least significant zero bit. - Sets the least significant zero bit of
`x`

and clears all other bits. - Sets the least significant zero bit of
`x`

and clears all bits above that bit. - Sets the least significant zero bit of
`x`

. - Sets all bits of
`x`

below the least significant one. - Extracts lowest set isolated bit.
- Clears least significant bit and sets all other bits.
- Gets mask up to lowest set bit.
- Resets the lowest set bit of
`x`

. - Returns an integer with the reversed byte order of x
- Zeroes higher bits of
`a`

>=`index`

. - Restores the
`XMM`

,`MMX`

,`MXCSR`

, and`x87`

FPU registers from the 512-byte-long 16-byte-aligned memory region`mem_addr`

. - Saves the
`x87`

FPU,`MMX`

technology,`XMM`

, and`MXCSR`

registers to the 512-byte-long 16-byte-aligned memory region`mem_addr`

. - Counts the leading most significant zero bits.
- Computes the absolute values of packed 8-bit integers in
`a`

. - Computes the absolute values of packed 16-bit integers in
`a`

. - Computes the absolute values of packed 32-bit integers in
`a`

. - Adds packed 8-bit integers in
`a`

and`b`

. - Adds packed 16-bit integers in
`a`

and`b`

. - Adds packed 32-bit integers in
`a`

and`b`

. - Adds packed 64-bit integers in
`a`

and`b`

. - Adds packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Adds packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Adds packed 8-bit integers in
`a`

and`b`

using saturation. - Adds packed 16-bit integers in
`a`

and`b`

using saturation. - Adds packed unsigned 8-bit integers in
`a`

and`b`

using saturation. - Adds packed unsigned 16-bit integers in
`a`

and`b`

using saturation. - Alternatively adds and subtracts packed double-precision (64-bit) floating-point elements in
`a`

to/from packed elements in`b`

. - Alternatively adds and subtracts packed single-precision (32-bit) floating-point elements in
`a`

to/from packed elements in`b`

. - Concatenates pairs of 16-byte blocks in
`a`

and`b`

into a 32-byte temporary result, shifts the result right by`n`

bytes, and returns the low 16 bytes. - Computes the bitwise AND of a packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise AND of packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise AND of 256 bits (representing integer data) in
`a`

and`b`

. - Computes the bitwise NOT of packed double-precision (64-bit) floating-point elements in
`a`

, and then AND with`b`

. - Computes the bitwise NOT of packed single-precision (32-bit) floating-point elements in
`a`

and then AND with`b`

. - Computes the bitwise NOT of 256 bits (representing integer data) in
`a`

and then AND with`b`

. - Averages packed unsigned 8-bit integers in
`a`

and`b`

. - Averages packed unsigned 16-bit integers in
`a`

and`b`

. - Blends packed 16-bit integers from
`a`

and`b`

using control mask`IMM8`

. - Blends packed 32-bit integers from
`a`

and`b`

using control mask`IMM8`

. - Blends packed double-precision (64-bit) floating-point elements from
`a`

and`b`

using control mask`imm8`

. - Blends packed single-precision (32-bit) floating-point elements from
`a`

and`b`

using control mask`imm8`

. - Blends packed 8-bit integers from
`a`

and`b`

using`mask`

. - Blends packed double-precision (64-bit) floating-point elements from
`a`

and`b`

using`c`

as a mask. - Blends packed single-precision (32-bit) floating-point elements from
`a`

and`b`

using`c`

as a mask. - Broadcasts 128 bits from memory (composed of 2 packed double-precision (64-bit) floating-point elements) to all elements of the returned vector.
- Broadcasts 128 bits from memory (composed of 4 packed single-precision (32-bit) floating-point elements) to all elements of the returned vector.
- Broadcasts a double-precision (64-bit) floating-point element from memory to all elements of the returned vector.
- Broadcasts a single-precision (32-bit) floating-point element from memory to all elements of the returned vector.
- Broadcasts the low packed 8-bit integer from
`a`

to all elements of the 256-bit returned value. - Broadcasts the low packed 32-bit integer from
`a`

to all elements of the 256-bit returned value. - Broadcasts the low packed 64-bit integer from
`a`

to all elements of the 256-bit returned value. - Broadcasts the low double-precision (64-bit) floating-point element from
`a`

to all elements of the 256-bit returned value. - Broadcasts 128 bits of integer data from a to all 128-bit lanes in the 256-bit returned value.
- Broadcasts the low single-precision (32-bit) floating-point element from
`a`

to all elements of the 256-bit returned value. - Broadcasts the low packed 16-bit integer from a to all elements of the 256-bit returned value
- Shifts 128-bit lanes in
`a`

left by`imm8`

bytes while shifting in zeros. - Shifts 128-bit lanes in
`a`

right by`imm8`

bytes while shifting in zeros. - Casts vector of type __m128d to type __m256d; the upper 128 bits of the result are undefined.
- Casts vector of type __m256d to type __m128d.
- Cast vector of type __m256d to type __m256.
- Casts vector of type __m256d to type __m256i.
- Casts vector of type __m128 to type __m256; the upper 128 bits of the result are undefined.
- Casts vector of type __m256 to type __m128.
- Cast vector of type __m256 to type __m256d.
- Casts vector of type __m256 to type __m256i.
- Casts vector of type __m128i to type __m256i; the upper 128 bits of the result are undefined.
- Casts vector of type __m256i to type __m256d.
- Casts vector of type __m256i to type __m256.
- Casts vector of type __m256i to type __m128i.
- Rounds packed double-precision (64-bit) floating point elements in
`a`

toward positive infinity. - Rounds packed single-precision (32-bit) floating point elements in
`a`

toward positive infinity. - Compares packed double-precision (64-bit) floating-point elements in
`a`

and`b`

based on the comparison operand specified by`IMM5`

. - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

based on the comparison operand specified by`IMM5`

. - Compares packed 8-bit integers in
`a`

and`b`

for equality. - Compares packed 16-bit integers in
`a`

and`b`

for equality. - Compares packed 32-bit integers in
`a`

and`b`

for equality. - Compares packed 64-bit integers in
`a`

and`b`

for equality. - Compares packed 8-bit integers in
`a`

and`b`

for greater-than. - Compares packed 16-bit integers in
`a`

and`b`

for greater-than. - Compares packed 32-bit integers in
`a`

and`b`

for greater-than. - Compares packed 64-bit integers in
`a`

and`b`

for greater-than. - Sign-extend 8-bit integers to 16-bit integers.
- Sign-extend 8-bit integers to 32-bit integers.
- Sign-extend 8-bit integers to 64-bit integers.
- Sign-extend 16-bit integers to 32-bit integers.
- Sign-extend 16-bit integers to 64-bit integers.
- Sign-extend 32-bit integers to 64-bit integers.
- Converts packed 32-bit integers in
`a`

to packed double-precision (64-bit) floating-point elements. - Converts packed 32-bit integers in
`a`

to packed single-precision (32-bit) floating-point elements. - Zero-extend unsigned 8-bit integers in
`a`

to 16-bit integers. - Zero-extend the lower eight unsigned 8-bit integers in
`a`

to 32-bit integers. The upper eight elements of`a`

are unused. - Zero-extend the lower four unsigned 8-bit integers in
`a`

to 64-bit integers. The upper twelve elements of`a`

are unused. - Zeroes extend packed unsigned 16-bit integers in
`a`

to packed 32-bit integers, and stores the results in`dst`

. - Zero-extend the lower four unsigned 16-bit integers in
`a`

to 64-bit integers. The upper four elements of`a`

are unused. - Zero-extend unsigned 32-bit integers in
`a`

to 64-bit integers. - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed 32-bit integers. - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed single-precision (32-bit) floating-point elements. - Converts the 8 x 16-bit half-precision float values in the 128-bit vector
`a`

into 8 x 32-bit float values stored in a 256-bit wide vector. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed 32-bit integers. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed double-precision (64-bit) floating-point elements. - Converts the 8 x 32-bit float values in the 256-bit vector
`a`

into 8 x 16-bit half-precision float values stored in a 128-bit wide vector. - Returns the first element of the input vector of
`[4 x double]`

. - Returns the first element of the input vector of
`[8 x i32]`

. - Returns the first element of the input vector of
`[8 x float]`

. - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed 32-bit integers with truncation. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed 32-bit integers with truncation. - Computes the division of each of the 4 packed 64-bit floating-point elements in
`a`

by the corresponding packed elements in`b`

. - Computes the division of each of the 8 packed 32-bit floating-point elements in
`a`

by the corresponding packed elements in`b`

. - Conditionally multiplies the packed single-precision (32-bit) floating-point elements in
`a`

and`b`

using the high 4 bits in`imm8`

, sum the four products, and conditionally return the sum using the low 4 bits of`imm8`

. - Extracts an 8-bit integer from
`a`

, selected with`INDEX`

. Returns a 32-bit integer containing the zero-extended integer data. - Extracts a 16-bit integer from
`a`

, selected with`INDEX`

. Returns a 32-bit integer containing the zero-extended integer data. - Extracts a 32-bit integer from
`a`

, selected with`INDEX`

. - Extracts 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from
`a`

, selected with`imm8`

. - Extracts 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from
`a`

, selected with`imm8`

. - Extracts 128 bits (composed of integer data) from
`a`

, selected with`imm8`

. - Extracts 128 bits (of integer data) from
`a`

selected with`IMM1`

. - Rounds packed double-precision (64-bit) floating point elements in
`a`

toward negative infinity. - Rounds packed single-precision (32-bit) floating point elements in
`a`

toward negative infinity. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to packed elements in`c`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to packed elements in`c`

. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and alternatively add and subtract packed elements in`c`

to/from the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and alternatively add and subtract packed elements in`c`

to/from the intermediate result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the intermediate result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and alternatively subtract and add packed elements in`c`

from/to the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and alternatively subtract and add packed elements in`c`

from/to the intermediate result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to packed elements in`c`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to packed elements in`c`

. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. - Horizontally adds adjacent pairs of 16-bit integers in
`a`

and`b`

. - Horizontally adds adjacent pairs of 32-bit integers in
`a`

and`b`

. - Horizontal addition of adjacent pairs in the two packed vectors of 4 64-bit floating points
`a`

and`b`

. In the result, sums of elements from`a`

are returned in even locations, while sums of elements from`b`

are returned in odd locations. - Horizontal addition of adjacent pairs in the two packed vectors of 8 32-bit floating points
`a`

and`b`

. In the result, sums of elements from`a`

are returned in locations of indices 0, 1, 4, 5; while sums of elements from`b`

are locations 2, 3, 6, 7. - Horizontally adds adjacent pairs of 16-bit integers in
`a`

and`b`

using saturation. - Horizontally subtract adjacent pairs of 16-bit integers in
`a`

and`b`

. - Horizontally subtract adjacent pairs of 32-bit integers in
`a`

and`b`

. - Horizontal subtraction of adjacent pairs in the two packed vectors of 4 64-bit floating points
`a`

and`b`

. In the result, sums of elements from`a`

are returned in even locations, while sums of elements from`b`

are returned in odd locations. - Horizontal subtraction of adjacent pairs in the two packed vectors of 8 32-bit floating points
`a`

and`b`

. In the result, sums of elements from`a`

are returned in locations of indices 0, 1, 4, 5; while sums of elements from`b`

are locations 2, 3, 6, 7. - Horizontally subtract adjacent pairs of 16-bit integers in
`a`

and`b`

using saturation. - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. `slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.- Copies
`a`

to result, and inserts the 8-bit integer`i`

into result at the location specified by`index`

. - Copies
`a`

to result, and inserts the 16-bit integer`i`

into result at the location specified by`index`

. - Copies
`a`

to result, and inserts the 32-bit integer`i`

into result at the location specified by`index`

. - Copies
`a`

to result, then inserts 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from`b`

into result at the location specified by`imm8`

. - Copies
`a`

to result, then inserts 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from`b`

into result at the location specified by`imm8`

. - Copies
`a`

to result, then inserts 128 bits from`b`

into result at the location specified by`imm8`

. - Copies
`a`

to`dst`

, then insert 128 bits (of integer data) from`b`

at the location specified by`IMM1`

. - Loads 256-bits of integer data from unaligned memory into result. This intrinsic may perform better than
`_mm256_loadu_si256`

when the data crosses a cache line boundary. - Loads 256-bits (composed of 4 packed double-precision (64-bit) floating-point elements) from memory into result.
`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Loads 256-bits (composed of 8 packed single-precision (32-bit) floating-point elements) from memory into result.
`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Loads 256-bits of integer data from memory into result.
`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Loads two 128-bit values (composed of 4 packed single-precision (32-bit) floating-point elements) from memory, and combine them into a 256-bit value.
`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Loads two 128-bit values (composed of 2 packed double-precision (64-bit) floating-point elements) from memory, and combine them into a 256-bit value.
`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Loads two 128-bit values (composed of integer data) from memory, and combine them into a 256-bit value.
`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Loads 256-bits (composed of 4 packed double-precision (64-bit) floating-point elements) from memory into result.
`mem_addr`

does not need to be aligned on any particular boundary. - Loads 256-bits (composed of 8 packed single-precision (32-bit) floating-point elements) from memory into result.
`mem_addr`

does not need to be aligned on any particular boundary. - Loads 256-bits of integer data from memory into result.
`mem_addr`

does not need to be aligned on any particular boundary. - Multiplies packed signed 16-bit integers in
`a`

and`b`

, producing intermediate signed 32-bit integers. Horizontally add adjacent pairs of intermediate 32-bit integers. - Vertically multiplies each unsigned 8-bit integer from
`a`

with the corresponding signed 8-bit integer from`b`

, producing intermediate signed 16-bit integers. Horizontally add adjacent pairs of intermediate signed 16-bit integers - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead. - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead. - Returns values from
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead. `slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.- Loads packed 32-bit integers from memory pointed by
`mem_addr`

using`mask`

(elements are zeroed out when the highest bit is not set in the corresponding element). - Loads packed 64-bit integers from memory pointed by
`mem_addr`

using`mask`

(elements are zeroed out when the highest bit is not set in the corresponding element). - Loads packed double-precision (64-bit) floating-point elements from memory into result using
`mask`

(elements are zeroed out when the high bit of the corresponding element is not set). - Loads packed single-precision (32-bit) floating-point elements from memory into result using
`mask`

(elements are zeroed out when the high bit of the corresponding element is not set). - Stores packed 32-bit integers from
`a`

into memory pointed by`mem_addr`

using`mask`

(elements are not stored when the highest bit is not set in the corresponding element). - Stores packed 64-bit integers from
`a`

into memory pointed by`mem_addr`

using`mask`

(elements are not stored when the highest bit is not set in the corresponding element). - Stores packed double-precision (64-bit) floating-point elements from
`a`

into memory using`mask`

. - Stores packed single-precision (32-bit) floating-point elements from
`a`

into memory using`mask`

. - Compares packed 8-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed 16-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed 32-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed unsigned 8-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed unsigned 16-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed unsigned 32-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and returns packed maximum values - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and returns packed maximum values - Compares packed 8-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed 16-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed 32-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed unsigned 8-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed unsigned 16-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed unsigned 32-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and returns packed minimum values - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and returns packed minimum values - Duplicate even-indexed double-precision (64-bit) floating-point elements from
`a`

, and returns the results. - Duplicate odd-indexed single-precision (32-bit) floating-point elements from
`a`

, and returns the results. - Duplicate even-indexed single-precision (32-bit) floating-point elements from
`a`

, and returns the results. - Creates mask from the most significant bit of each 8-bit element in
`a`

, return the result. - Sets each bit of the returned mask based on the most significant bit of the corresponding packed double-precision (64-bit) floating-point element in
`a`

. - Sets each bit of the returned mask based on the most significant bit of the corresponding packed single-precision (32-bit) floating-point element in
`a`

. - Computes the sum of absolute differences (SADs) of quadruplets of unsigned 8-bit integers in
`a`

compared to those in`b`

, and stores the 16-bit results in dst. Eight SADs are performed for each 128-bit lane using one quadruplet from`b`

and eight quadruplets from`a`

. One quadruplet is selected from`b`

starting at on the offset specified in`imm8`

. Eight quadruplets are formed from sequential 8-bit integers selected from`a`

starting at the offset specified in`imm8`

. - Multiplies the low 32-bit integers from each packed 64-bit element in
`a`

and`b`

- Multiplies the low unsigned 32-bit integers from each packed 64-bit element in
`a`

and`b`

- Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Multiplies the packed 16-bit integers in
`a`

and`b`

, producing intermediate 32-bit integers and returning the high 16 bits of the intermediate integers. - Multiplies the packed unsigned 16-bit integers in
`a`

and`b`

, producing intermediate 32-bit integers and returning the high 16 bits of the intermediate integers. - Multiplies packed 16-bit integers in
`a`

and`b`

, producing intermediate signed 32-bit integers. Truncate each intermediate integer to the 18 most significant bits, round by adding 1, and return bits`[16:1]`

. - Multiplies the packed 16-bit integers in
`a`

and`b`

, producing intermediate 32-bit integers, and returns the low 16 bits of the intermediate integers - Multiplies the packed 32-bit integers in
`a`

and`b`

, producing intermediate 64-bit integers, and returns the low 32 bits of the intermediate integers - Computes the bitwise OR packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise OR packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise OR of 256 bits (representing integer data) in
`a`

and`b`

- Converts packed 16-bit integers from
`a`

and`b`

to packed 8-bit integers using signed saturation - Converts packed 32-bit integers from
`a`

and`b`

to packed 16-bit integers using signed saturation - Converts packed 16-bit integers from
`a`

and`b`

to packed 8-bit integers using unsigned saturation - Converts packed 32-bit integers from
`a`

and`b`

to packed 16-bit integers using unsigned saturation - Shuffles 256 bits (composed of 4 packed double-precision (64-bit) floating-point elements) selected by
`imm8`

from`a`

and`b`

. - Shuffles 256 bits (composed of 8 packed single-precision (32-bit) floating-point elements) selected by
`imm8`

from`a`

and`b`

. - Shuffles 128-bits (composed of integer data) selected by
`imm8`

from`a`

and`b`

. - Shuffles 128-bits of integer data selected by
`imm8`

from`a`

and`b`

. - Permutes 64-bit integers from
`a`

using control mask`imm8`

. - Shuffles 64-bit floating-point elements in
`a`

across lanes using the control in`imm8`

. - Shuffles double-precision (64-bit) floating-point elements in
`a`

within 128-bit lanes using the control in`imm8`

. - Shuffles single-precision (32-bit) floating-point elements in
`a`

within 128-bit lanes using the control in`imm8`

. - Permutes packed 32-bit integers from
`a`

according to the content of`b`

. - Shuffles eight 32-bit floating-point elements in
`a`

across lanes using the corresponding 32-bit integer index in`idx`

. - Shuffles double-precision (64-bit) floating-point elements in
`a`

within 256-bit lanes using the control in`b`

. - Shuffles single-precision (32-bit) floating-point elements in
`a`

within 128-bit lanes using the control in`b`

. - Computes the approximate reciprocal of packed single-precision (32-bit) floating-point elements in
`a`

, and returns the results. The maximum relative error for this approximation is less than 1.5*2^-12. - Rounds packed double-precision (64-bit) floating point elements in
`a`

according to the flag`ROUNDING`

. The value of`ROUNDING`

may be as follows: - Rounds packed single-precision (32-bit) floating point elements in
`a`

according to the flag`ROUNDING`

. The value of`ROUNDING`

may be as follows: - Computes the approximate reciprocal square root of packed single-precision (32-bit) floating-point elements in
`a`

, and returns the results. The maximum relative error for this approximation is less than 1.5*2^-12. - Computes the absolute differences of packed unsigned 8-bit integers in
`a`

and`b`

, then horizontally sum each consecutive 8 differences to produce four unsigned 16-bit integers, and pack these unsigned 16-bit integers in the low 16 bits of the 64-bit return value - Broadcasts 8-bit integer
`a`

to all elements of returned vector. This intrinsic may generate the`vpbroadcastb`

. - Broadcasts 16-bit integer
`a`

to all elements of returned vector. This intrinsic may generate the`vpbroadcastw`

. - Broadcasts 32-bit integer
`a`

to all elements of returned vector. This intrinsic may generate the`vpbroadcastd`

. - Broadcasts 64-bit integer
`a`

to all elements of returned vector. This intrinsic may generate the`vpbroadcastq`

. - Broadcasts double-precision (64-bit) floating-point value
`a`

to all elements of returned vector. - Broadcasts single-precision (32-bit) floating-point value
`a`

to all elements of returned vector. - Sets packed 8-bit integers in returned vector with the supplied values.
- Sets packed 16-bit integers in returned vector with the supplied values.
- Sets packed 32-bit integers in returned vector with the supplied values.
- Sets packed 64-bit integers in returned vector with the supplied values.
- Sets packed __m256 returned vector with the supplied values.
- Sets packed __m256d returned vector with the supplied values.
- Sets packed __m256i returned vector with the supplied values.
- Sets packed double-precision (64-bit) floating-point elements in returned vector with the supplied values.
- Sets packed single-precision (32-bit) floating-point elements in returned vector with the supplied values.
- Sets packed 8-bit integers in returned vector with the supplied values in reverse order.
- Sets packed 16-bit integers in returned vector with the supplied values in reverse order.
- Sets packed 32-bit integers in returned vector with the supplied values in reverse order.
- Sets packed 64-bit integers in returned vector with the supplied values in reverse order.
- Sets packed __m256 returned vector with the supplied values.
- Sets packed __m256d returned vector with the supplied values.
- Sets packed __m256i returned vector with the supplied values.
- Sets packed double-precision (64-bit) floating-point elements in returned vector with the supplied values in reverse order.
- Sets packed single-precision (32-bit) floating-point elements in returned vector with the supplied values in reverse order.
- Returns vector of type __m256d with all elements set to zero.
- Returns vector of type __m256 with all elements set to zero.
- Returns vector of type __m256i with all elements set to zero.
- Shuffles bytes from
`a`

according to the content of`b`

. - Shuffles 32-bit integers in 128-bit lanes of
`a`

using the control in`imm8`

. - Shuffles double-precision (64-bit) floating-point elements within 128-bit lanes using the control in
`imm8`

. - Shuffles single-precision (32-bit) floating-point elements in
`a`

within 128-bit lanes using the control in`imm8`

. - Shuffles 16-bit integers in the high 64 bits of 128-bit lanes of
`a`

using the control in`imm8`

. The low 64 bits of 128-bit lanes of`a`

are copied to the output. - Shuffles 16-bit integers in the low 64 bits of 128-bit lanes of
`a`

using the control in`imm8`

. The high 64 bits of 128-bit lanes of`a`

are copied to the output. - Negates packed 8-bit integers in
`a`

when the corresponding signed 8-bit integer in`b`

is negative, and returns the results. Results are zeroed out when the corresponding element in`b`

is zero. - Negates packed 16-bit integers in
`a`

when the corresponding signed 16-bit integer in`b`

is negative, and returns the results. Results are zeroed out when the corresponding element in`b`

is zero. - Negates packed 32-bit integers in
`a`

when the corresponding signed 32-bit integer in`b`

is negative, and returns the results. Results are zeroed out when the corresponding element in`b`

is zero. - Shifts packed 16-bit integers in
`a`

left by`count`

while shifting in zeros, and returns the result - Shifts packed 32-bit integers in
`a`

left by`count`

while shifting in zeros, and returns the result - Shifts packed 64-bit integers in
`a`

left by`count`

while shifting in zeros, and returns the result - Shifts packed 16-bit integers in
`a`

left by`IMM8`

while shifting in zeros, return the results; - Shifts packed 32-bit integers in
`a`

left by`IMM8`

while shifting in zeros, return the results; - Shifts packed 64-bit integers in
`a`

left by`IMM8`

while shifting in zeros, return the results; - Shifts 128-bit lanes in
`a`

left by`imm8`

bytes while shifting in zeros. - Shifts packed 32-bit integers in
`a`

left by the amount specified by the corresponding element in`count`

while shifting in zeros, and returns the result. - Shifts packed 64-bit integers in
`a`

left by the amount specified by the corresponding element in`count`

while shifting in zeros, and returns the result. - Returns the square root of packed double-precision (64-bit) floating point elements in
`a`

. - Returns the square root of packed single-precision (32-bit) floating point elements in
`a`

. - Shifts packed 16-bit integers in
`a`

right by`count`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by`count`

while shifting in sign bits. - Shifts packed 16-bit integers in
`a`

right by`IMM8`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by`IMM8`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in sign bits. - Shifts packed 16-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 32-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 64-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 16-bit integers in
`a`

right by`IMM8`

while shifting in zeros - Shifts packed 32-bit integers in
`a`

right by`IMM8`

while shifting in zeros - Shifts packed 64-bit integers in
`a`

right by`IMM8`

while shifting in zeros - Shifts 128-bit lanes in
`a`

right by`imm8`

bytes while shifting in zeros. - Shifts packed 32-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in zeros, - Shifts packed 64-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in zeros, - Stores 256-bits (composed of 4 packed double-precision (64-bit) floating-point elements) from
`a`

into memory.`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Stores 256-bits (composed of 8 packed single-precision (32-bit) floating-point elements) from
`a`

into memory.`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Stores 256-bits of integer data from
`a`

into memory.`mem_addr`

must be aligned on a 32-byte boundary or a general-protection exception may be generated. - Stores the high and low 128-bit halves (each composed of 4 packed single-precision (32-bit) floating-point elements) from
`a`

into memory two different 128-bit locations.`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Stores the high and low 128-bit halves (each composed of 2 packed double-precision (64-bit) floating-point elements) from
`a`

into memory two different 128-bit locations.`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Stores the high and low 128-bit halves (each composed of integer data) from
`a`

into memory two different 128-bit locations.`hiaddr`

and`loaddr`

do not need to be aligned on any particular boundary. - Stores 256-bits (composed of 4 packed double-precision (64-bit) floating-point elements) from
`a`

into memory.`mem_addr`

does not need to be aligned on any particular boundary. - Stores 256-bits (composed of 8 packed single-precision (32-bit) floating-point elements) from
`a`

into memory.`mem_addr`

does not need to be aligned on any particular boundary. - Stores 256-bits of integer data from
`a`

into memory.`mem_addr`

does not need to be aligned on any particular boundary. - Load 256-bits of integer data from memory into dst using a non-temporal memory hint. mem_addr must be aligned on a 32-byte boundary or a general-protection exception may be generated. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon)
- Moves double-precision values from a 256-bit vector of
`[4 x double]`

to a 32-byte aligned memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon). - Moves single-precision floating point values from a 256-bit vector of
`[8 x float]`

to a 32-byte aligned memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon). - Moves integer data from a 256-bit integer vector to a 32-byte aligned memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon)
- Subtract packed 8-bit integers in
`b`

from packed 8-bit integers in`a`

- Subtract packed 16-bit integers in
`b`

from packed 16-bit integers in`a`

- Subtract packed 32-bit integers in
`b`

from packed 32-bit integers in`a`

- Subtract packed 64-bit integers in
`b`

from packed 64-bit integers in`a`

- Subtracts packed double-precision (64-bit) floating-point elements in
`b`

from packed elements in`a`

. - Subtracts packed single-precision (32-bit) floating-point elements in
`b`

from packed elements in`a`

. - Subtract packed 8-bit integers in
`b`

from packed 8-bit integers in`a`

using saturation. - Subtract packed 16-bit integers in
`b`

from packed 16-bit integers in`a`

using saturation. - Subtract packed unsigned 8-bit integers in
`b`

from packed 8-bit integers in`a`

using saturation. - Subtract packed unsigned 16-bit integers in
`b`

from packed 16-bit integers in`a`

using saturation. - Computes the bitwise AND of 256 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`CF`

value. - Computes the bitwise AND of 256 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`CF`

value. - Computes the bitwise AND of 256 bits (representing integer data) in
`a`

and`b`

, and set`ZF`

to 1 if the result is zero, otherwise set`ZF`

to 0. Computes the bitwise NOT of`a`

and then AND with`b`

, and set`CF`

to 1 if the result is zero, otherwise set`CF`

to 0. Return the`CF`

value. - Computes the bitwise AND of 256 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return 1 if both the`ZF`

and`CF`

values are zero, otherwise return 0. - Computes the bitwise AND of 256 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return 1 if both the`ZF`

and`CF`

values are zero, otherwise return 0. - Computes the bitwise AND of 256 bits (representing integer data) in
`a`

and`b`

, and set`ZF`

to 1 if the result is zero, otherwise set`ZF`

to 0. Computes the bitwise NOT of`a`

and then AND with`b`

, and set`CF`

to 1 if the result is zero, otherwise set`CF`

to 0. Return 1 if both the`ZF`

and`CF`

values are zero, otherwise return 0. - Computes the bitwise AND of 256 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`ZF`

value. - Computes the bitwise AND of 256 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 256-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`ZF`

value. - Computes the bitwise AND of 256 bits (representing integer data) in
`a`

and`b`

, and set`ZF`

to 1 if the result is zero, otherwise set`ZF`

to 0. Computes the bitwise NOT of`a`

and then AND with`b`

, and set`CF`

to 1 if the result is zero, otherwise set`CF`

to 0. Return the`ZF`

value. - Returns vector of type
`__m256d`

with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Returns vector of type
`__m256`

with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Returns vector of type __m256i with with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to
`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Unpacks and interleave 8-bit integers from the high half of each 128-bit lane in
`a`

and`b`

. - Unpacks and interleave 16-bit integers from the high half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave 32-bit integers from the high half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave 64-bit integers from the high half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave double-precision (64-bit) floating-point elements from the high half of each 128-bit lane in
`a`

and`b`

. - Unpacks and interleave single-precision (32-bit) floating-point elements from the high half of each 128-bit lane in
`a`

and`b`

. - Unpacks and interleave 8-bit integers from the low half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave 16-bit integers from the low half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave 32-bit integers from the low half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave 64-bit integers from the low half of each 128-bit lane of
`a`

and`b`

. - Unpacks and interleave double-precision (64-bit) floating-point elements from the low half of each 128-bit lane in
`a`

and`b`

. - Unpacks and interleave single-precision (32-bit) floating-point elements from the low half of each 128-bit lane in
`a`

and`b`

. - Computes the bitwise XOR of packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise XOR of packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Computes the bitwise XOR of 256 bits (representing integer data) in
`a`

and`b`

- Zeroes the contents of all XMM or YMM registers.
- Zeroes the upper 128 bits of all YMM registers; the lower 128-bits of the registers are unmodified.
- Constructs a 256-bit floating-point vector of
`[4 x double]`

from a 128-bit floating-point vector of`[2 x double]`

. The lower 128 bits contain the value of the source vector. The upper 128 bits are set to zero. - Constructs a 256-bit floating-point vector of
`[8 x float]`

from a 128-bit floating-point vector of`[4 x float]`

. The lower 128 bits contain the value of the source vector. The upper 128 bits are set to zero. - Constructs a 256-bit integer vector from a 128-bit integer vector. The lower 128 bits contain the value of the source vector. The upper 128 bits are set to zero.
- Computes the absolute value of packed 8-bit signed integers in
`a`

and return the unsigned results. - Computes the absolute value of each of the packed 16-bit signed integers in
`a`

and return the 16-bit unsigned integer - Computes the absolute value of each of the packed 32-bit signed integers in
`a`

and return the 32-bit unsigned integer - Adds packed 8-bit integers in
`a`

and`b`

. - Adds packed 16-bit integers in
`a`

and`b`

. - Adds packed 32-bit integers in
`a`

and`b`

. - Adds packed 64-bit integers in
`a`

and`b`

. - Adds packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Adds packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Returns a new vector with the low element of
`a`

replaced by the sum of the low elements of`a`

and`b`

. - Adds the first component of
`a`

and`b`

, the other components are copied from`a`

. - Adds packed 8-bit integers in
`a`

and`b`

using saturation. - Adds packed 16-bit integers in
`a`

and`b`

using saturation. - Adds packed unsigned 8-bit integers in
`a`

and`b`

using saturation. - Adds packed unsigned 16-bit integers in
`a`

and`b`

using saturation. - Alternatively add and subtract packed double-precision (64-bit) floating-point elements in
`a`

to/from packed elements in`b`

. - Alternatively add and subtract packed single-precision (32-bit) floating-point elements in
`a`

to/from packed elements in`b`

. - Performs one round of an AES decryption flow on data (state) in
`a`

. - Performs the last round of an AES decryption flow on data (state) in
`a`

. - Performs one round of an AES encryption flow on data (state) in
`a`

. - Performs the last round of an AES encryption flow on data (state) in
`a`

. - Performs the
`InvMixColumns`

transformation on`a`

. - Assist in expanding the AES cipher key.
- Concatenate 16-byte blocks in
`a`

and`b`

into a 32-byte temporary result, shift the result right by`n`

bytes, and returns the low 16 bytes. - Computes the bitwise AND of packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Bitwise AND of packed single-precision (32-bit) floating-point elements.
- Computes the bitwise AND of 128 bits (representing integer data) in
`a`

and`b`

. - Computes the bitwise NOT of
`a`

and then AND with`b`

. - Bitwise AND-NOT of packed single-precision (32-bit) floating-point elements.
- Computes the bitwise NOT of 128 bits (representing integer data) in
`a`

and then AND with`b`

. - Averages packed unsigned 8-bit integers in
`a`

and`b`

. - Averages packed unsigned 16-bit integers in
`a`

and`b`

. - Blend packed 16-bit integers from
`a`

and`b`

using the mask`IMM8`

. - Blends packed 32-bit integers from
`a`

and`b`

using control mask`IMM4`

. - Blend packed double-precision (64-bit) floating-point elements from
`a`

and`b`

using control mask`IMM2`

- Blend packed single-precision (32-bit) floating-point elements from
`a`

and`b`

using mask`IMM4`

- Blend packed 8-bit integers from
`a`

and`b`

using`mask`

- Blend packed double-precision (64-bit) floating-point elements from
`a`

and`b`

using`mask`

- Blend packed single-precision (32-bit) floating-point elements from
`a`

and`b`

using`mask`

- Broadcasts a single-precision (32-bit) floating-point element from memory to all elements of the returned vector.
- Broadcasts the low packed 8-bit integer from
`a`

to all elements of the 128-bit returned value. - Broadcasts the low packed 32-bit integer from
`a`

to all elements of the 128-bit returned value. - Broadcasts the low packed 64-bit integer from
`a`

to all elements of the 128-bit returned value. - Broadcasts the low double-precision (64-bit) floating-point element from
`a`

to all elements of the 128-bit returned value. - Broadcasts 128 bits of integer data from a to all 128-bit lanes in the 256-bit returned value.
- Broadcasts the low single-precision (32-bit) floating-point element from
`a`

to all elements of the 128-bit returned value. - Broadcasts the low packed 16-bit integer from a to all elements of the 128-bit returned value
- Shifts
`a`

left by`IMM8`

bytes while shifting in zeros. - Shifts
`a`

right by`IMM8`

bytes while shifting in zeros. - Casts a 128-bit floating-point vector of
`[2 x double]`

into a 128-bit floating-point vector of`[4 x float]`

. - Casts a 128-bit floating-point vector of
`[2 x double]`

into a 128-bit integer vector. - Casts a 128-bit floating-point vector of
`[4 x float]`

into a 128-bit floating-point vector of`[2 x double]`

. - Casts a 128-bit floating-point vector of
`[4 x float]`

into a 128-bit integer vector. - Casts a 128-bit integer vector into a 128-bit floating-point vector of
`[2 x double]`

. - Casts a 128-bit integer vector into a 128-bit floating-point vector of
`[4 x float]`

. - Round the packed double-precision (64-bit) floating-point elements in
`a`

up to an integer value, and stores the results as packed double-precision floating-point elements. - Round the packed single-precision (32-bit) floating-point elements in
`a`

up to an integer value, and stores the results as packed single-precision floating-point elements. - Round the lower double-precision (64-bit) floating-point element in
`b`

up to an integer value, store the result as a double-precision floating-point element in the lower element of the intrinsic result, and copies the upper element from`a`

to the upper element of the intrinsic result. - Round the lower single-precision (32-bit) floating-point element in
`b`

up to an integer value, store the result as a single-precision floating-point element in the lower element of the intrinsic result, and copies the upper 3 packed elements from`a`

to the upper elements of the intrinsic result. - Invalidates and flushes the cache line that contains
`p`

from all levels of the cache hierarchy. - Performs a carry-less multiplication of two 64-bit polynomials over the finite field GF(2).
- Compares packed double-precision (64-bit) floating-point elements in
`a`

and`b`

based on the comparison operand specified by`IMM5`

. - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

based on the comparison operand specified by`IMM5`

. - Compares the lower double-precision (64-bit) floating-point element in
`a`

and`b`

based on the comparison operand specified by`IMM5`

, store the result in the lower element of returned vector, and copies the upper element from`a`

to the upper element of returned vector. - Compares the lower single-precision (32-bit) floating-point element in
`a`

and`b`

based on the comparison operand specified by`IMM5`

, store the result in the lower element of returned vector, and copies the upper 3 packed elements from`a`

to the upper elements of returned vector. - Compares packed 8-bit integers in
`a`

and`b`

for equality. - Compares packed 16-bit integers in
`a`

and`b`

for equality. - Compares packed 32-bit integers in
`a`

and`b`

for equality. - Compares packed 64-bit integers in
`a`

and`b`

for equality - Compares corresponding elements in
`a`

and`b`

for equality. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input elements were equal, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the equality comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for equality. The lowest 32 bits of the result will be`0xffffffff`

if the two inputs are equal, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return`1`

if`b`

did not contain a null character and the resulting mask was zero, and`0`

otherwise. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return`1`

if the resulting mask was non-zero, and`0`

otherwise. - Compares packed strings
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

and return the generated index. Similar to`_mm_cmpistri`

with the exception that`_mm_cmpistri`

implicitly determines the length of`a`

and`b`

. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return the generated mask. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return bit`0`

of the resulting bit mask. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return`1`

if any character in a was null, and`0`

otherwise. - Compares packed strings in
`a`

and`b`

with lengths`la`

and`lb`

using the control in`IMM8`

, and return`1`

if any character in`b`

was null, and`0`

otherwise. - Compares corresponding elements in
`a`

and`b`

for greater-than-or-equal. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is greater than or equal to the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the greater-than-or-equal comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for greater than or equal. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is greater than or equal`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares packed 8-bit integers in
`a`

and`b`

for greater-than. - Compares packed 16-bit integers in
`a`

and`b`

for greater-than. - Compares packed 32-bit integers in
`a`

and`b`

for greater-than. - Compares packed 64-bit integers in
`a`

and`b`

for greater-than, return the results. - Compares corresponding elements in
`a`

and`b`

for greater-than. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is greater than the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the greater-than comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for greater than. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is greater than`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and return`1`

if`b`

did not contain a null character and the resulting mask was zero, and`0`

otherwise. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and return`1`

if the resulting mask was non-zero, and`0`

otherwise. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

and return the generated index. Similar to`_mm_cmpestri`

with the exception that`_mm_cmpestri`

requires the lengths of`a`

and`b`

to be explicitly specified. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and return the generated mask. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and return bit`0`

of the resulting bit mask. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and returns`1`

if any character in`a`

was null, and`0`

otherwise. - Compares packed strings with implicit lengths in
`a`

and`b`

using the control in`IMM8`

, and return`1`

if any character in`b`

was null. and`0`

otherwise. - Compares corresponding elements in
`a`

and`b`

for less-than-or-equal - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is less than or equal to the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the less-than-or-equal comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for less than or equal. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is less than or equal`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares packed 8-bit integers in
`a`

and`b`

for less-than. - Compares packed 16-bit integers in
`a`

and`b`

for less-than. - Compares packed 32-bit integers in
`a`

and`b`

for less-than. - Compares corresponding elements in
`a`

and`b`

for less-than. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is less than the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the less-than comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for less than. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is less than`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

for not-equal. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input elements are**not**equal, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the not-equal comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for inequality. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is not equal to`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

for not-greater-than-or-equal. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is**not**greater than or equal to the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the not-greater-than-or-equal comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for not-greater-than-or-equal. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is not greater than or equal to`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

for not-greater-than. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is**not**greater than the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the not-greater-than comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for not-greater-than. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is not greater than`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

for not-less-than-or-equal. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is**not**less than or equal to the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the not-less-than-or-equal comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for not-less-than-or-equal. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is not less than or equal to`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

for not-less-than. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. The result in the output vector will be`0xffffffff`

if the input element in`a`

is**not**less than the corresponding element in`b`

, or`0`

otherwise. - Returns a new vector with the low element of
`a`

replaced by the not-less-than comparison of the lower elements of`a`

and`b`

. - Compares the lowest
`f32`

of both inputs for not-less-than. The lowest 32 bits of the result will be`0xffffffff`

if`a.extract(0)`

is not less than`b.extract(0)`

, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

to see if neither is`NaN`

. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. Returns four floats that have one of two possible bit patterns. The element in the output vector will be`0xffffffff`

if the input elements in`a`

and`b`

are ordered (i.e., neither of them is a NaN), or 0 otherwise. - Returns a new vector with the low element of
`a`

replaced by the result of comparing both of the lower elements of`a`

and`b`

to`NaN`

. If neither are equal to`NaN`

then`0xFFFFFFFFFFFFFFFF`

is used and`0`

otherwise. - Checks if the lowest
`f32`

of both inputs are ordered. The lowest 32 bits of the result will be`0xffffffff`

if neither of`a.extract(0)`

or`b.extract(0)`

is a NaN, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares corresponding elements in
`a`

and`b`

to see if either is`NaN`

. - Compares each of the four floats in
`a`

to the corresponding element in`b`

. Returns four floats that have one of two possible bit patterns. The element in the output vector will be`0xffffffff`

if the input elements in`a`

and`b`

are unordered (i.e., at least on of them is a NaN), or 0 otherwise. - Returns a new vector with the low element of
`a`

replaced by the result of comparing both of the lower elements of`a`

and`b`

to`NaN`

. If either is equal to`NaN`

then`0xFFFFFFFFFFFFFFFF`

is used and`0`

otherwise. - Checks if the lowest
`f32`

of both inputs are unordered. The lowest 32 bits of the result will be`0xffffffff`

if any of`a.extract(0)`

or`b.extract(0)`

is a NaN, or`0`

otherwise. The upper 96 bits of the result are the upper 96 bits of`a`

. - Compares the lower element of
`a`

and`b`

for equality. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if they are equal, or`0`

otherwise. - Compares the lower element of
`a`

and`b`

for greater-than-or-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is greater than or equal to the one from`b`

, or`0`

otherwise. - Compares the lower element of
`a`

and`b`

for greater-than. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is greater than the one from`b`

, or`0`

otherwise. - Compares the lower element of
`a`

and`b`

for less-than-or-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is less than or equal to the one from`b`

, or`0`

otherwise. - Compares the lower element of
`a`

and`b`

for less-than. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is less than the one from`b`

, or`0`

otherwise. - Compares the lower element of
`a`

and`b`

for not-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if they are**not**equal, or`0`

otherwise. - Starting with the initial value in
`crc`

, return the accumulated CRC32-C value for unsigned 8-bit integer`v`

. - Starting with the initial value in
`crc`

, return the accumulated CRC32-C value for unsigned 16-bit integer`v`

. - Starting with the initial value in
`crc`

, return the accumulated CRC32-C value for unsigned 32-bit integer`v`

. - Alias for
`_mm_cvtsi32_ss`

. - Alias for
`_mm_cvtss_si32`

. - Sign extend packed 8-bit integers in
`a`

to packed 16-bit integers - Sign extend packed 8-bit integers in
`a`

to packed 32-bit integers - Sign extend packed 8-bit integers in the low 8 bytes of
`a`

to packed 64-bit integers - Sign extend packed 16-bit integers in
`a`

to packed 32-bit integers - Sign extend packed 16-bit integers in
`a`

to packed 64-bit integers - Sign extend packed 32-bit integers in
`a`

to packed 64-bit integers - Converts the lower two packed 32-bit integers in
`a`

to packed double-precision (64-bit) floating-point elements. - Converts packed 32-bit integers in
`a`

to packed single-precision (32-bit) floating-point elements. - Zeroes extend packed unsigned 8-bit integers in
`a`

to packed 16-bit integers - Zeroes extend packed unsigned 8-bit integers in
`a`

to packed 32-bit integers - Zeroes extend packed unsigned 8-bit integers in
`a`

to packed 64-bit integers - Zeroes extend packed unsigned 16-bit integers in
`a`

to packed 32-bit integers - Zeroes extend packed unsigned 16-bit integers in
`a`

to packed 64-bit integers - Zeroes extend packed unsigned 32-bit integers in
`a`

to packed 64-bit integers - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed 32-bit integers. - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed single-precision (32-bit) floating-point elements - Converts the 4 x 16-bit half-precision float values in the lowest 64-bit of the 128-bit vector
`a`

into 4 x 32-bit float values stored in a 128-bit wide vector. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed 32-bit integers. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed double-precision (64-bit) floating-point elements. - Converts the 4 x 32-bit float values in the 128-bit vector
`a`

into 4 x 16-bit half-precision float values stored in the lowest 64-bit of a 128-bit vector. - Returns the lower double-precision (64-bit) floating-point element of
`a`

. - Converts the lower double-precision (64-bit) floating-point element in a to a 32-bit integer.
- Converts the lower double-precision (64-bit) floating-point element in
`b`

to a single-precision (32-bit) floating-point element, store the result in the lower element of the return value, and copies the upper element from`a`

to the upper element the return value. - Returns
`a`

with its lower element replaced by`b`

after converting it to an`f64`

. - Returns a vector whose lowest element is
`a`

and all higher elements are`0`

. - Converts a 32 bit integer to a 32 bit float. The result vector is the input vector
`a`

with the lowest 32 bit float replaced by the converted integer. - Returns the lowest element of
`a`

. - Extracts the lowest 32 bit float from the input vector.
- Converts the lower single-precision (32-bit) floating-point element in
`b`

to a double-precision (64-bit) floating-point element, store the result in the lower element of the return value, and copies the upper element from`a`

to the upper element the return value. - Converts the lowest 32 bit float in the input vector to a 32 bit integer.
- Alias for
`_mm_cvttss_si32`

. - Converts packed double-precision (64-bit) floating-point elements in
`a`

to packed 32-bit integers with truncation. - Converts packed single-precision (32-bit) floating-point elements in
`a`

to packed 32-bit integers with truncation. - Converts the lower double-precision (64-bit) floating-point element in
`a`

to a 32-bit integer with truncation. - Converts the lowest 32 bit float in the input vector to a 32 bit integer with truncation.
- Divide packed double-precision (64-bit) floating-point elements in
`a`

by packed elements in`b`

. - Divides packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Returns a new vector with the low element of
`a`

replaced by the result of diving the lower element of`a`

by the lower element of`b`

. - Divides the first component of
`b`

by`a`

, the other components are copied from`a`

. - Returns the dot product of two __m128d vectors.
- Returns the dot product of two __m128 vectors.
- Extracts an 8-bit integer from
`a`

, selected with`IMM8`

. Returns a 32-bit integer containing the zero-extended integer data. - Returns the
`imm8`

element of`a`

. - Extracts an 32-bit integer from
`a`

selected with`IMM8`

- Extracts a single-precision (32-bit) floating-point element from
`a`

, selected with`IMM8`

. The returned`i32`

stores the float’s bit-pattern, and may be converted back to a floating point number via casting. - Extracts the bit range specified by
`y`

from the lower 64 bits of`x`

. - Extracts the specified bits from the lower 64 bits of the 128-bit integer vector operand at the index
`idx`

and of the length`len`

. - Round the packed double-precision (64-bit) floating-point elements in
`a`

down to an integer value, and stores the results as packed double-precision floating-point elements. - Round the packed single-precision (32-bit) floating-point elements in
`a`

down to an integer value, and stores the results as packed single-precision floating-point elements. - Round the lower double-precision (64-bit) floating-point element in
`b`

down to an integer value, store the result as a double-precision floating-point element in the lower element of the intrinsic result, and copies the upper element from`a`

to the upper element of the intrinsic result. - Round the lower single-precision (32-bit) floating-point element in
`b`

down to an integer value, store the result as a single-precision floating-point element in the lower element of the intrinsic result, and copies the upper 3 packed elements from`a`

to the upper elements of the intrinsic result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to packed elements in`c`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to packed elements in`c`

. - Multiplies the lower double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to the lower element in`c`

. Stores the result in the lower element of the returned value, and copy the upper element from`a`

to the upper elements of the result. - Multiplies the lower single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the intermediate result to the lower element in`c`

. Stores the result in the lower element of the returned value, and copy the 3 upper elements from`a`

to the upper elements of the result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and alternatively add and subtract packed elements in`c`

to/from the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and alternatively add and subtract packed elements in`c`

to/from the intermediate result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the intermediate result. - Multiplies the lower double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract the lower element in`c`

from the intermediate result. Store the result in the lower element of the returned value, and copy the upper element from`a`

to the upper elements of the result. - Multiplies the lower single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract the lower element in`c`

from the intermediate result. Store the result in the lower element of the returned value, and copy the 3 upper elements from`a`

to the upper elements of the result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and alternatively subtract and add packed elements in`c`

from/to the intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and alternatively subtract and add packed elements in`c`

from/to the intermediate result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to packed elements in`c`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to packed elements in`c`

. - Multiplies the lower double-precision (64-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to the lower element in`c`

. Store the result in the lower element of the returned value, and copy the upper element from`a`

to the upper elements of the result. - Multiplies the lower single-precision (32-bit) floating-point elements in
`a`

and`b`

, and add the negated intermediate result to the lower element in`c`

. Store the result in the lower element of the returned value, and copy the 3 upper elements from`a`

to the upper elements of the result. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. - Multiplies the lower double-precision (64-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. Store the result in the lower element of the returned value, and copy the upper element from`a`

to the upper elements of the result. - Multiplies the lower single-precision (32-bit) floating-point elements in
`a`

and`b`

, and subtract packed elements in`c`

from the negated intermediate result. Store the result in the lower element of the returned value, and copy the 3 upper elements from`a`

to the upper elements of the result. - Gets the unsigned 32-bit value of the MXCSR control and status register.
- Horizontally adds the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[8 x i16]`

. - Horizontally adds the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[4 x i32]`

. - Horizontally adds adjacent pairs of double-precision (64-bit) floating-point elements in
`a`

and`b`

, and pack the results. - Horizontally adds adjacent pairs of single-precision (32-bit) floating-point elements in
`a`

and`b`

, and pack the results. - Horizontally adds the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[8 x i16]`

. Positive sums greater than 7FFFh are saturated to 7FFFh. Negative sums less than 8000h are saturated to 8000h. - Horizontally subtract the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[8 x i16]`

. - Horizontally subtract the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[4 x i32]`

. - Horizontally subtract adjacent pairs of double-precision (64-bit) floating-point elements in
`a`

and`b`

, and pack the results. - Horizontally adds adjacent pairs of single-precision (32-bit) floating-point elements in
`a`

and`b`

, and pack the results. - Horizontally subtract the adjacent pairs of values contained in 2 packed 128-bit vectors of
`[8 x i16]`

. Positive differences greater than 7FFFh are saturated to 7FFFh. Negative differences less than 8000h are saturated to 8000h. `slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8.- Returns a copy of
`a`

with the 8-bit integer from`i`

inserted at a location specified by`IMM8`

. - Returns a new vector where the
`imm8`

element of`a`

is replaced with`i`

. - Returns a copy of
`a`

with the 32-bit integer from`i`

inserted at a location specified by`IMM8`

. - Select a single value in
`b`

to store at some position in`a`

, Then zero elements according to`IMM8`

. - Inserts the
`[length:0]`

bits of`y`

into`x`

at`index`

. - Inserts the
`len`

least-significant bits from the lower 64 bits of the 128-bit integer vector operand`y`

into the lower 64 bits of the 128-bit integer vector operand`x`

at the index`idx`

and of the length`len`

. - Loads 128-bits of integer data from unaligned memory. This intrinsic may perform better than
`_mm_loadu_si128`

when the data crosses a cache line boundary. - Performs a serializing operation on all load-from-memory instructions that were issued prior to this instruction.
- Loads a double-precision (64-bit) floating-point element from memory into both elements of returned vector.
- Construct a
`__m128`

by duplicating the value read from`p`

into all elements. - Loads 128-bits (composed of 2 packed double-precision (64-bit) floating-point elements) from memory into the returned vector.
`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Loads a double-precision (64-bit) floating-point element from memory into both elements of returned vector.
- Loads four
`f32`

values from*aligned*memory into a`__m128`

. If the pointer is not aligned to a 128-bit boundary (16 bytes) a general protection fault will be triggered (fatal program crash). - Alias for
`_mm_load1_ps`

- Loads a 64-bit double-precision value to the low element of a 128-bit integer vector and clears the upper element.
- Loads 128-bits of integer data from memory into a new vector.
- Construct a
`__m128`

with the lowest element read from`p`

and the other elements set to zero. - Loads a double-precision (64-bit) floating-point element from memory into both elements of return vector.
- Loads a double-precision value into the high-order bits of a 128-bit vector of
`[2 x double]`

. The low-order bits are copied from the low-order bits of the first operand. - Loads 64-bit integer from memory into first element of returned vector.
- Loads a double-precision value into the low-order bits of a 128-bit vector of
`[2 x double]`

. The high-order bits are copied from the high-order bits of the first operand. - Loads 2 double-precision (64-bit) floating-point elements from memory into the returned vector in reverse order.
`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Loads four
`f32`

values from aligned memory into a`__m128`

in reverse order. - Loads 128-bits (composed of 2 packed double-precision (64-bit) floating-point elements) from memory into the returned vector.
`mem_addr`

does not need to be aligned on any particular boundary. - Loads four
`f32`

values from memory into a`__m128`

. There are no restrictions on memory alignment. For aligned memory`_mm_load_ps`

may be faster. - Loads unaligned 16-bits of integer data from memory into new vector.
- Loads unaligned 32-bits of integer data from memory into new vector.
- Loads unaligned 16-bits of integer data from memory into new vector.
- Loads 128-bits of integer data from memory into a new vector.
- Multiplies and then horizontally add signed 16 bit integers in
`a`

and`b`

. - Multiplies corresponding pairs of packed 8-bit unsigned integer values contained in the first source operand and packed 8-bit signed integer values contained in the second source operand, add pairs of contiguous products with signed saturation, and writes the 16-bit sums to the corresponding bits in the destination.
`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.`slice`

at offsets determined by`offsets * scale`

, where`scale`

should be 1, 2, 4 or 8. If mask is set, load the value from`src`

in that position instead.- Loads packed 32-bit integers from memory pointed by
`mem_addr`

using`mask`

(elements are zeroed out when the highest bit is not set in the corresponding element). - Loads packed 64-bit integers from memory pointed by
`mem_addr`

using`mask`

(elements are zeroed out when the highest bit is not set in the corresponding element). - Loads packed double-precision (64-bit) floating-point elements from memory into result using
`mask`

(elements are zeroed out when the high bit of the corresponding element is not set). - Loads packed single-precision (32-bit) floating-point elements from memory into result using
`mask`

(elements are zeroed out when the high bit of the corresponding element is not set). - Conditionally store 8-bit integer elements from
`a`

into memory using`mask`

. - Stores packed 32-bit integers from
`a`

into memory pointed by`mem_addr`

using`mask`

(elements are not stored when the highest bit is not set in the corresponding element). - Stores packed 64-bit integers from
`a`

into memory pointed by`mem_addr`

using`mask`

(elements are not stored when the highest bit is not set in the corresponding element). - Stores packed double-precision (64-bit) floating-point elements from
`a`

into memory using`mask`

. - Stores packed single-precision (32-bit) floating-point elements from
`a`

into memory using`mask`

. - Compares packed 8-bit integers in
`a`

and`b`

and returns packed maximum values in dst. - Compares packed 16-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed 32-bit integers in
`a`

and`b`

, and returns packed maximum values. - Compares packed unsigned 8-bit integers in
`a`

and`b`

, and returns the packed maximum values. - Compares packed unsigned 16-bit integers in
`a`

and`b`

, and returns packed maximum. - Compares packed unsigned 32-bit integers in
`a`

and`b`

, and returns packed maximum values. - Returns a new vector with the maximum values from corresponding elements in
`a`

and`b`

. - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and return the corresponding maximum values. - Returns a new vector with the low element of
`a`

replaced by the maximum of the lower elements of`a`

and`b`

. - Compares the first single-precision (32-bit) floating-point element of
`a`

and`b`

, and return the maximum value in the first element of the return value, the other elements are copied from`a`

. - Performs a serializing operation on all load-from-memory and store-to-memory instructions that were issued prior to this instruction.
- Compares packed 8-bit integers in
`a`

and`b`

and returns packed minimum values in dst. - Compares packed 16-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed 32-bit integers in
`a`

and`b`

, and returns packed minimum values. - Compares packed unsigned 8-bit integers in
`a`

and`b`

, and returns the packed minimum values. - Compares packed unsigned 16-bit integers in
`a`

and`b`

, and returns packed minimum. - Compares packed unsigned 32-bit integers in
`a`

and`b`

, and returns packed minimum values. - Returns a new vector with the minimum values from corresponding elements in
`a`

and`b`

. - Compares packed single-precision (32-bit) floating-point elements in
`a`

and`b`

, and return the corresponding minimum values. - Returns a new vector with the low element of
`a`

replaced by the minimum of the lower elements of`a`

and`b`

. - Compares the first single-precision (32-bit) floating-point element of
`a`

and`b`

, and return the minimum value in the first element of the return value, the other elements are copied from`a`

. - Finds the minimum unsigned 16-bit element in the 128-bit __m128i vector, returning a vector containing its value in its first position, and its index in its second position; all other elements are set to zero.
- Returns a vector where the low element is extracted from
`a`

and its upper element is zero. - Constructs a 128-bit floating-point vector of
`[2 x double]`

. The lower 64 bits are set to the lower 64 bits of the second parameter. The upper 64 bits are set to the upper 64 bits of the first parameter. - Returns a
`__m128`

with the first component from`b`

and the remaining components from`a`

. - Duplicate the low double-precision (64-bit) floating-point element from
`a`

. - Duplicate odd-indexed single-precision (32-bit) floating-point elements from
`a`

. - Combine higher half of
`a`

and`b`

. The higher half of`b`

occupies the lower half of result. - Duplicate even-indexed single-precision (32-bit) floating-point elements from
`a`

. - Combine lower half of
`a`

and`b`

. The lower half of`b`

occupies the higher half of result. - Returns a mask of the most significant bit of each element in
`a`

. - Returns a mask of the most significant bit of each element in
`a`

. - Returns a mask of the most significant bit of each element in
`a`

. - Subtracts 8-bit unsigned integer values and computes the absolute values of the differences to the corresponding bits in the destination. Then sums of the absolute differences are returned according to the bit fields in the immediate operand.
- Multiplies the low 32-bit integers from each packed 64-bit element in
`a`

and`b`

, and returns the signed 64-bit result. - Multiplies the low unsigned 32-bit integers from each packed 64-bit element in
`a`

and`b`

. - Multiplies packed double-precision (64-bit) floating-point elements in
`a`

and`b`

. - Multiplies packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Returns a new vector with the low element of
`a`

replaced by multiplying the low elements of`a`

and`b`

. - Multiplies the first component of
`a`

and`b`

, the other components are copied from`a`

. - Multiplies the packed 16-bit integers in
`a`

and`b`

. - Multiplies the packed unsigned 16-bit integers in
`a`

and`b`

. - Multiplies packed 16-bit signed integer values, truncate the 32-bit product to the 18 most significant bits by right-shifting, round the truncated value by adding 1, and write bits
`[16:1]`

to the destination. - Multiplies the packed 16-bit integers in
`a`

and`b`

. - Multiplies the packed 32-bit integers in
`a`

and`b`

, producing intermediate 64-bit integers, and returns the lowest 32-bit, whatever they might be, reinterpreted as a signed integer. While`pmulld __m128i::splat(2), __m128i::splat(2)`

returns the obvious`__m128i::splat(4)`

, due to wrapping arithmetic`pmulld __m128i::splat(i32::MAX), __m128i::splat(2)`

would return a negative number. - Computes the bitwise OR of
`a`

and`b`

. - Bitwise OR of packed single-precision (32-bit) floating-point elements.
- Computes the bitwise OR of 128 bits (representing integer data) in
`a`

and`b`

. - Converts packed 16-bit integers from
`a`

and`b`

to packed 8-bit integers using signed saturation. - Converts packed 32-bit integers from
`a`

and`b`

to packed 16-bit integers using signed saturation. - Converts packed 16-bit integers from
`a`

and`b`

to packed 8-bit integers using unsigned saturation. - Converts packed 32-bit integers from
`a`

and`b`

to packed 16-bit integers using unsigned saturation - Provides a hint to the processor that the code sequence is a spin-wait loop.
- Shuffles double-precision (64-bit) floating-point elements in
`a`

using the control in`imm8`

. - Shuffles single-precision (32-bit) floating-point elements in
`a`

using the control in`imm8`

. - Shuffles double-precision (64-bit) floating-point elements in
`a`

using the control in`b`

. - Shuffles single-precision (32-bit) floating-point elements in
`a`

using the control in`b`

. - Fetch the cache line that contains address
`p`

using the given`STRATEGY`

. - Returns the approximate reciprocal of packed single-precision (32-bit) floating-point elements in
`a`

. - Returns the approximate reciprocal of the first single-precision (32-bit) floating-point element in
`a`

, the other elements are unchanged. - Round the packed double-precision (64-bit) floating-point elements in
`a`

using the`ROUNDING`

parameter, and stores the results as packed double-precision floating-point elements. Rounding is done according to the rounding parameter, which can be one of: - Round the packed single-precision (32-bit) floating-point elements in
`a`

using the`ROUNDING`

parameter, and stores the results as packed single-precision floating-point elements. Rounding is done according to the rounding parameter, which can be one of: - Round the lower double-precision (64-bit) floating-point element in
`b`

using the`ROUNDING`

parameter, store the result as a double-precision floating-point element in the lower element of the intrinsic result, and copies the upper element from`a`

to the upper element of the intrinsic result. Rounding is done according to the rounding parameter, which can be one of: - Round the lower single-precision (32-bit) floating-point element in
`b`

using the`ROUNDING`

parameter, store the result as a single-precision floating-point element in the lower element of the intrinsic result, and copies the upper 3 packed elements from`a`

to the upper elements of the intrinsic result. Rounding is done according to the rounding parameter, which can be one of: - Returns the approximate reciprocal square root of packed single-precision (32-bit) floating-point elements in
`a`

. - Returns the approximate reciprocal square root of the first single-precision (32-bit) floating-point element in
`a`

, the other elements are unchanged. - Sum the absolute differences of packed unsigned 8-bit integers.
- Broadcasts 8-bit integer
`a`

to all elements. - Broadcasts 16-bit integer
`a`

to all elements. - Broadcasts 32-bit integer
`a`

to all elements. - Broadcasts 64-bit integer
`a`

to all elements. - Broadcasts double-precision (64-bit) floating-point value a to all elements of the return value.
- Construct a
`__m128`

with all element set to`a`

. - Sets packed 8-bit integers with the supplied values.
- Sets packed 16-bit integers with the supplied values.
- Sets packed 32-bit integers with the supplied values.
- Sets packed 64-bit integers with the supplied values, from highest to lowest.
- Sets packed double-precision (64-bit) floating-point elements in the return value with the supplied values.
- Broadcasts double-precision (64-bit) floating-point value a to all elements of the return value.
- Construct a
`__m128`

from four floating point values highest to lowest. - Alias for
`_mm_set1_ps`

- Copies double-precision (64-bit) floating-point element
`a`

to the lower element of the packed 64-bit return value. - Construct a
`__m128`

with the lowest element set to`a`

and the rest set to zero. - Sets the MXCSR register with the 32-bit unsigned integer value.
- Sets packed 8-bit integers with the supplied values in reverse order.
- Sets packed 16-bit integers with the supplied values in reverse order.
- Sets packed 32-bit integers with the supplied values in reverse order.
- Sets packed double-precision (64-bit) floating-point elements in the return value with the supplied values in reverse order.
- Construct a
`__m128`

from four floating point values lowest to highest. - Returns packed double-precision (64-bit) floating-point elements with all zeros.
- Construct a
`__m128`

with all elements initialized to zero. - Returns a vector with all elements set to zero.
- Performs a serializing operation on all non-temporal (“streaming”) store instructions that were issued by the current thread prior to this instruction.
- Performs an intermediate calculation for the next four SHA1 message values (unsigned 32-bit integers) using previous message values from
`a`

and`b`

, and returning the result. - Performs the final calculation for the next four SHA1 message values (unsigned 32-bit integers) using the intermediate result in
`a`

and the previous message values in`b`

, and returns the result. - Calculate SHA1 state variable E after four rounds of operation from the current SHA1 state variable
`a`

, add that value to the scheduled values (unsigned 32-bit integers) in`b`

, and returns the result. - Performs four rounds of SHA1 operation using an initial SHA1 state (A,B,C,D) from
`a`

and some pre-computed sum of the next 4 round message values (unsigned 32-bit integers), and state variable E from`b`

, and return the updated SHA1 state (A,B,C,D).`FUNC`

contains the logic functions and round constants. - Performs an intermediate calculation for the next four SHA256 message values (unsigned 32-bit integers) using previous message values from
`a`

and`b`

, and return the result. - Performs the final calculation for the next four SHA256 message values (unsigned 32-bit integers) using previous message values from
`a`

and`b`

, and return the result. - Performs 2 rounds of SHA256 operation using an initial SHA256 state (C,D,G,H) from
`a`

, an initial SHA256 state (A,B,E,F) from`b`

, and a pre-computed sum of the next 2 round message values (unsigned 32-bit integers) and the corresponding round constants from`k`

, and store the updated SHA256 state (A,B,E,F) in dst. - Shuffles bytes from
`a`

according to the content of`b`

. - Shuffles 32-bit integers in
`a`

using the control in`IMM8`

. - Constructs a 128-bit floating-point vector of
`[2 x double]`

from two 128-bit vector parameters of`[2 x double]`

, using the immediate-value parameter as a specifier. - Shuffles packed single-precision (32-bit) floating-point elements in
`a`

and`b`

using`MASK`

. - Shuffles 16-bit integers in the high 64 bits of
`a`

using the control in`IMM8`

. - Shuffles 16-bit integers in the low 64 bits of
`a`

using the control in`IMM8`

. - Negates packed 8-bit integers in
`a`

when the corresponding signed 8-bit integer in`b`

is negative, and returns the result. Elements in result are zeroed out when the corresponding element in`b`

is zero. - Negates packed 16-bit integers in
`a`

when the corresponding signed 16-bit integer in`b`

is negative, and returns the results. Elements in result are zeroed out when the corresponding element in`b`

is zero. - Negates packed 32-bit integers in
`a`

when the corresponding signed 32-bit integer in`b`

is negative, and returns the results. Element in result are zeroed out when the corresponding element in`b`

is zero. - Shifts packed 16-bit integers in
`a`

left by`count`

while shifting in zeros. - Shifts packed 32-bit integers in
`a`

left by`count`

while shifting in zeros. - Shifts packed 64-bit integers in
`a`

left by`count`

while shifting in zeros. - Shifts packed 16-bit integers in
`a`

left by`IMM8`

while shifting in zeros. - Shifts packed 32-bit integers in
`a`

left by`IMM8`

while shifting in zeros. - Shifts packed 64-bit integers in
`a`

left by`IMM8`

while shifting in zeros. - Shifts
`a`

left by`IMM8`

bytes while shifting in zeros. - Shifts packed 32-bit integers in
`a`

left by the amount specified by the corresponding element in`count`

while shifting in zeros, and returns the result. - Shifts packed 64-bit integers in
`a`

left by the amount specified by the corresponding element in`count`

while shifting in zeros, and returns the result. - Returns a new vector with the square root of each of the values in
`a`

. - Returns the square root of packed single-precision (32-bit) floating-point elements in
`a`

. - Returns a new vector with the low element of
`a`

replaced by the square root of the lower element`b`

. - Returns the square root of the first single-precision (32-bit) floating-point element in
`a`

, the other elements are unchanged. - Shifts packed 16-bit integers in
`a`

right by`count`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by`count`

while shifting in sign bits. - Shifts packed 16-bit integers in
`a`

right by`IMM8`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by`IMM8`

while shifting in sign bits. - Shifts packed 32-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in sign bits. - Shifts packed 16-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 32-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 64-bit integers in
`a`

right by`count`

while shifting in zeros. - Shifts packed 16-bit integers in
`a`

right by`IMM8`

while shifting in zeros. - Shifts packed 32-bit integers in
`a`

right by`IMM8`

while shifting in zeros. - Shifts packed 64-bit integers in
`a`

right by`IMM8`

while shifting in zeros. - Shifts
`a`

right by`IMM8`

bytes while shifting in zeros. - Shifts packed 32-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in zeros, - Shifts packed 64-bit integers in
`a`

right by the amount specified by the corresponding element in`count`

while shifting in zeros, - Stores the lower double-precision (64-bit) floating-point element from
`a`

into 2 contiguous elements in memory.`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Stores the lowest 32 bit float of
`a`

repeated four times into*aligned*memory. - Stores 128-bits (composed of 2 packed double-precision (64-bit) floating-point elements) from
`a`

into memory.`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Stores the lower double-precision (64-bit) floating-point element from
`a`

into 2 contiguous elements in memory.`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Stores four 32-bit floats into
*aligned*memory. - Alias for
`_mm_store1_ps`

- Stores the lower 64 bits of a 128-bit vector of
`[2 x double]`

to a memory location. - Stores 128-bits of integer data from
`a`

into memory. - Stores the lowest 32 bit float of
`a`

into memory. - Stores the upper 64 bits of a 128-bit vector of
`[2 x double]`

to a memory location. - Stores the lower 64-bit integer
`a`

to a memory location. - Stores the lower 64 bits of a 128-bit vector of
`[2 x double]`

to a memory location. - Stores 2 double-precision (64-bit) floating-point elements from
`a`

into memory in reverse order.`mem_addr`

must be aligned on a 16-byte boundary or a general-protection exception may be generated. - Stores four 32-bit floats into
*aligned*memory in reverse order. - Stores 128-bits (composed of 2 packed double-precision (64-bit) floating-point elements) from
`a`

into memory.`mem_addr`

does not need to be aligned on any particular boundary. - Stores four 32-bit floats into memory. There are no restrictions on memory alignment. For aligned memory
`_mm_store_ps`

may be faster. - Store 16-bit integer from the first element of a into memory.
- Store 32-bit integer from the first element of a into memory.
- Store 64-bit integer from the first element of a into memory.
- Stores 128-bits of integer data from
`a`

into memory. - Load 128-bits of integer data from memory into dst. mem_addr must be aligned on a 16-byte boundary or a general-protection exception may be generated. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon)
- Stores a 128-bit floating point vector of
`[2 x double]`

to a 128-bit aligned memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon). - Stores
`a`

into the memory at`mem_addr`

using a non-temporal memory hint. - Non-temporal store of
`a.0`

into`p`

. - Stores a 32-bit integer value in the specified memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon).
- Stores a 128-bit integer vector to a 128-bit aligned memory location. To minimize caching, the data is flagged as non-temporal (unlikely to be used again soon).
- Non-temporal store of
`a.0`

into`p`

. - Subtracts packed 8-bit integers in
`b`

from packed 8-bit integers in`a`

. - Subtracts packed 16-bit integers in
`b`

from packed 16-bit integers in`a`

. - Subtract packed 32-bit integers in
`b`

from packed 32-bit integers in`a`

. - Subtract packed 64-bit integers in
`b`

from packed 64-bit integers in`a`

. - Subtract packed double-precision (64-bit) floating-point elements in
`b`

from`a`

. - Subtracts packed single-precision (32-bit) floating-point elements in
`a`

and`b`

. - Returns a new vector with the low element of
`a`

replaced by subtracting the low element by`b`

from the low element of`a`

. - Subtracts the first component of
`b`

from`a`

, the other components are copied from`a`

. - Subtract packed 8-bit integers in
`b`

from packed 8-bit integers in`a`

using saturation. - Subtract packed 16-bit integers in
`b`

from packed 16-bit integers in`a`

using saturation. - Subtract packed unsigned 8-bit integers in
`b`

from packed unsigned 8-bit integers in`a`

using saturation. - Subtract packed unsigned 16-bit integers in
`b`

from packed unsigned 16-bit integers in`a`

using saturation. - Tests whether the specified bits in
`a`

128-bit integer vector are all ones. - Tests whether the specified bits in a 128-bit integer vector are all zeros.
- Tests whether the specified bits in a 128-bit integer vector are neither all zeros nor all ones.
- Computes the bitwise AND of 128 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`CF`

value. - Computes the bitwise AND of 128 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`CF`

value. - Tests whether the specified bits in a 128-bit integer vector are all ones.
- Computes the bitwise AND of 128 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return 1 if both the`ZF`

and`CF`

values are zero, otherwise return 0. - Computes the bitwise AND of 128 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return 1 if both the`ZF`

and`CF`

values are zero, otherwise return 0. - Tests whether the specified bits in a 128-bit integer vector are neither all zeros nor all ones.
- Computes the bitwise AND of 128 bits (representing double-precision (64-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 64-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`ZF`

value. - Computes the bitwise AND of 128 bits (representing single-precision (32-bit) floating-point elements) in
`a`

and`b`

, producing an intermediate 128-bit value, and set`ZF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`ZF`

to 0. Compute the bitwise NOT of`a`

and then AND with`b`

, producing an intermediate value, and set`CF`

to 1 if the sign bit of each 32-bit element in the intermediate value is zero, otherwise set`CF`

to 0. Return the`ZF`

value. - Tests whether the specified bits in a 128-bit integer vector are all zeros.
- Counts the number of trailing least significant zero bits.
- Compares the lower element of
`a`

and`b`

for equality. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if they are equal, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Compares the lower element of
`a`

and`b`

for greater-than-or-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is greater than or equal to the one from`b`

, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Compares the lower element of
`a`

and`b`

for greater-than. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is greater than the one from`b`

, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Compares the lower element of
`a`

and`b`

for less-than-or-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is less than or equal to the one from`b`

, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Compares the lower element of
`a`

and`b`

for less-than. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if the value from`a`

is less than the one from`b`

, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Compares the lower element of
`a`

and`b`

for not-equal. - Compares two 32-bit floats from the low-order bits of
`a`

and`b`

. Returns`1`

if they are**not**equal, or`0`

otherwise. This instruction will not signal an exception if either argument is a quiet NaN. - Returns vector of type __m128d with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to
`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Returns vector of type __m128 with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to
`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Returns vector of type __m128i with indeterminate elements. Despite being “undefined”, this is some valid value and not equivalent to
`mem::MaybeUninit`

. In practice, this is equivalent to`mem::zeroed`

. - Unpacks and interleave 8-bit integers from the high half of
`a`

and`b`

. - Unpacks and interleave 16-bit integers from the high half of
`a`

and`b`

. - Unpacks and interleave 32-bit integers from the high half of
`a`

and`b`

. - Unpacks and interleave 64-bit integers from the high half of
`a`

and`b`

. - The resulting
`__m128d`

element is composed by the low-order values of the two`__m128d`

interleaved input elements, i.e.: - Unpacks and interleave single-precision (32-bit) floating-point elements from the higher half of
`a`

and`b`

. - Unpacks and interleave 8-bit integers from the low half of
`a`

and`b`

. - Unpacks and interleave 16-bit integers from the low half of
`a`

and`b`

. - Unpacks and interleave 32-bit integers from the low half of
`a`

and`b`

. - Unpacks and interleave 64-bit integers from the low half of
`a`

and`b`

. - The resulting
`__m128d`

element is composed by the high-order values of the two`__m128d`

interleaved input elements, i.e.: - Unpacks and interleave single-precision (32-bit) floating-point elements from the lower half of
`a`

and`b`

. - Computes the bitwise XOR of
`a`

and`b`

. - Bitwise exclusive OR of packed single-precision (32-bit) floating-point elements.
- Computes the bitwise XOR of 128 bits (representing integer data) in
`a`

and`b`

. - Unsigned multiply without affecting flags.
- Scatter contiguous low order bits of
`a`

to the result at the positions specified by the`mask`

. - Gathers the bits of
`x`

specified by the`mask`

into the contiguous low order bit positions of the result. - Counts the bits that are set.
- Read a hardware generated 16-bit random value and store the result in val. Returns 1 if a random value was generated, and 0 otherwise.
- Read a hardware generated 32-bit random value and store the result in val. Returns 1 if a random value was generated, and 0 otherwise.
- Read a 16-bit NIST SP800-90B and SP800-90C compliant random value and store in val. Return 1 if a random value was generated, and 0 otherwise.
- Read a 32-bit NIST SP800-90B and SP800-90C compliant random value and store in val. Return 1 if a random value was generated, and 0 otherwise.
- Reads the current value of the processor’s time-stamp counter.
- Adds unsigned 32-bit integers
`a`

and`b`

with unsigned 8-bit carry-in`c_in`

(carry or overflow flag), and store the unsigned 32-bit result in`out`

, and the carry-out is returned (carry or overflow flag). - Clears all bits below the least significant zero of
`x`

and sets all other bits. - Counts the number of trailing least significant zero bits.
- Counts the number of trailing least significant zero bits.
- Sets all bits below the least significant one of
`x`

and clears all other bits. - Reads the contents of the extended control register
`XCR`

specified in`xcr_no`

. - Performs a full or partial restore of the enabled processor states using the state information stored in memory at
`mem_addr`

. - Performs a full or partial restore of the enabled processor states using the state information stored in memory at
`mem_addr`

. - Performs a full or partial save of the enabled processor states to memory at
`mem_addr`

. - Performs a full or partial save of the enabled processor states to memory at
`mem_addr`

. - Performs a full or partial save of the enabled processor states to memory at
`mem_addr`

. - Performs a full or partial save of the enabled processor states to memory at
`mem_addr`

- Copies 64-bits from
`val`

to the extended control register (`XCR`

) specified by`a`

. - _MM_
SHUFFLE Experimental x86 or x86-64 A utility function for creating masks to use with Intel shuffle and permute intrinsics. - Convert 8-bit mask a to a 32-bit integer value and store the result in dst.
- Convert 16-bit mask a into an integer value, and store the result in dst.
- Convert 32-bit mask a into an integer value, and store the result in dst.
- Convert 32-bit integer value a to an 8-bit mask and store the result in dst.
- Convert 32-bit integer value a to an 16-bit mask and store the result in dst.
- Convert integer value a into an 32-bit mask, and store the result in k.
- Add 8-bit masks a and b, and store the result in dst.
- Add 16-bit masks a and b, and store the result in dst.
- Add 32-bit masks in a and b, and store the result in k.
- Add 64-bit masks in a and b, and store the result in k.
- Bitwise AND of 8-bit masks a and b, and store the result in dst.
- Compute the bitwise AND of 16-bit masks a and b, and store the result in k.
- Compute the bitwise AND of 32-bit masks a and b, and store the result in k.
- Compute the bitwise AND of 64-bit masks a and b, and store the result in k.
- Bitwise AND NOT of 8-bit masks a and b, and store the result in dst.
- Compute the bitwise NOT of 16-bit masks a and then AND with b, and store the result in k.
- Compute the bitwise NOT of 32-bit masks a and then AND with b, and store the result in k.
- Compute the bitwise NOT of 64-bit masks a and then AND with b, and store the result in k.
- Bitwise NOT of 8-bit mask a, and store the result in dst.
- Compute the bitwise NOT of 16-bit mask a, and store the result in k.
- Compute the bitwise NOT of 32-bit mask a, and store the result in k.
- Compute the bitwise NOT of 64-bit mask a, and store the result in k.
- Bitwise OR of 8-bit masks a and b, and store the result in dst.
- Compute the bitwise OR of 16-bit masks a and b, and store the result in k.
- Compute the bitwise OR of 32-bit masks a and b, and store the result in k.
- Compute the bitwise OR of 64-bit masks a and b, and store the result in k.
- Compute the bitwise OR of 8-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst. If the result is all ones, store 1 in all_ones, otherwise store 0 in all_ones.
- Compute the bitwise OR of 16-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst. If the result is all ones, store 1 in all_ones, otherwise store 0 in all_ones.
- Compute the bitwise OR of 32-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst. If the result is all ones, store 1 in all_ones, otherwise store 0 in all_ones.
- Compute the bitwise OR of 64-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst. If the result is all ones, store 1 in all_ones, otherwise store 0 in all_ones.
- Compute the bitwise OR of 8-bit masks a and b. If the result is all ones, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 16-bit masks a and b. If the result is all ones, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 32-bit masks a and b. If the result is all ones, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 64-bit masks a and b. If the result is all ones, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 8-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 16-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 32-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise OR of 64-bit masks a and b. If the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Shift 8-bit mask a left by count bits while shifting in zeros, and store the result in dst.
- Shift 16-bit mask a left by count bits while shifting in zeros, and store the result in dst.
- Shift the bits of 32-bit mask a left by count while shifting in zeros, and store the least significant 32 bits of the result in k.
- Shift the bits of 64-bit mask a left by count while shifting in zeros, and store the least significant 32 bits of the result in k.
- Shift 8-bit mask a right by count bits while shifting in zeros, and store the result in dst.
- Shift 16-bit mask a right by count bits while shifting in zeros, and store the result in dst.
- Shift the bits of 32-bit mask a right by count while shifting in zeros, and store the least significant 32 bits of the result in k.
- Shift the bits of 64-bit mask a right by count while shifting in zeros, and store the least significant 32 bits of the result in k.
- Compute the bitwise AND of 8-bit masks a and b, and if the result is all zeros, store 1 in dst, otherwise store 0 in dst. Compute the bitwise NOT of a and then AND with b, if the result is all zeros, store 1 in and_not, otherwise store 0 in and_not.
- Compute the bitwise AND of 16-bit masks a and b, and if the result is all zeros, store 1 in dst, otherwise store 0 in dst. Compute the bitwise NOT of a and then AND with b, if the result is all zeros, store 1 in and_not, otherwise store 0 in and_not.
- Compute the bitwise AND of 32-bit masks a and b, and if the result is all zeros, store 1 in dst, otherwise store 0 in dst. Compute the bitwise NOT of a and then AND with b, if the result is all zeros, store 1 in and_not, otherwise store 0 in and_not.
- Compute the bitwise AND of 64-bit masks a and b, and if the result is all zeros, store 1 in dst, otherwise store 0 in dst. Compute the bitwise NOT of a and then AND with b, if the result is all zeros, store 1 in and_not, otherwise store 0 in and_not.
- Compute the bitwise NOT of 8-bit mask a and then AND with 8-bit mask b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise NOT of 16-bit mask a and then AND with 16-bit mask b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise NOT of 32-bit mask a and then AND with 16-bit mask b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise NOT of 64-bit mask a and then AND with 8-bit mask b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise AND of 8-bit masks a and b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise AND of 16-bit masks a and b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise AND of 32-bit masks a and b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Compute the bitwise AND of 64-bit masks a and b, if the result is all zeros, store 1 in dst, otherwise store 0 in dst.
- Bitwise XNOR of 8-bit masks a and b, and store the result in dst.
- Compute the bitwise XNOR of 16-bit masks a and b, and store the result in k.
- Compute the bitwise XNOR of 32-bit masks a and b, and store the result in k.
- Compute the bitwise XNOR of 64-bit masks a and b, and store the result in k.
- Bitwise XOR of 8-bit masks a and b, and store the result in dst.
- Compute the bitwise XOR of 16-bit masks a and b, and store the result in k.
- Compute the bitwise XOR of 32-bit masks a and b, and store the result in k.
- Compute the bitwise XOR of 64-bit masks a and b, and store the result in k.
- Load 8-bit mask from memory
- Load 16-bit mask from memory
- Load 32-bit mask from memory into k.
- Load 64-bit mask from memory into k.
- Compute the absolute value of packed signed 64-bit integers in a, and store the unsigned results in dst.
- Finds the absolute value of each packed half-precision (16-bit) floating-point element in v2, storing the result in dst.
- Add packed half-precision (16-bit) floating-point elements in a and b, and store the results in dst.
- Performs one round of an AES decryption flow on each 128-bit word (state) in
`a`

using the corresponding 128-bit word (key) in`round_key`

. - Performs the last round of an AES decryption flow on each 128-bit word (state) in
`a`

using the corresponding 128-bit word (key) in`round_key`

. - Performs one round of an AES encryption flow on each 128-bit word (state) in
`a`

using the corresponding 128-bit word (key) in`round_key`

. - Performs the last round of an AES encryption flow on each 128-bit word (state) in
`a`

using the corresponding 128-bit word (key) in`round_key`

. - Concatenate a and b into a 64-byte immediate result, shift the result right by imm8 32-bit elements, and store the low 32 bytes (8 elements) in dst.
- Concatenate a and b into a 64-byte immediate result, shift the result right by imm8 64-bit elements, and store the low 32 bytes (4 elements) in dst.
- Convert scalar BF16 (16-bit) floating point element stored at memory locations starting at location a to single precision (32-bit) floating-point, broadcast it to packed single precision (32-bit) floating-point elements, and store the results in dst.
- Convert scalar half-precision (16-bit) floating-point element stored at memory locations starting at location a to a single-precision (32-bit) floating-point, broadcast it to packed single-precision (32-bit) floating-point elements, and store the results in dst.
- Considers the input
`b`

as packed 64-bit integers and`c`

as packed 8-bit integers. Then groups 8 8-bit values from`c`

as indices into the bits of the corresponding 64-bit integer. It then selects these bits and packs them into the output. - Broadcasts the lower 2 packed single-precision (32-bit) floating-point elements from a to all elements of dst.
- Broadcast the 4 packed single-precision (32-bit) floating-point elements from a to all elements of dst.
- Broadcasts the 2 packed double-precision (64-bit) floating-point elements from a to all elements of dst.
- Broadcasts the lower 2 packed 32-bit integers from a to all elements of dst.
- Broadcast the 4 packed 32-bit integers from a to all elements of dst.
- Broadcasts the 2 packed 64-bit integers from a to all elements of dst.
- Broadcast the low 8-bits from input mask k to all 64-bit elements of dst.
- Broadcast the low 16-bits from input mask k to all 32-bit elements of dst.
- Cast vector of type
`__m256d`

to type`__m256h`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m128h`

to type`__m256h`

. The upper 8 elements of the result are undefined. In practice, the upper elements are zeroed. This intrinsic can generate the`vzeroupper`

instruction, but most of the time it does not generate any instructions. - Cast vector of type
`__m256h`

to type`__m128h`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m256h`

to type`__m256d`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m256h`

to type`__m256`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m256h`

to type`__m256i`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m256`

to type`__m256h`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Cast vector of type
`__m256i`

to type`__m256h`

. This intrinsic is only used for compilation and does not generate any instructions, thus it has zero latency. - Performs a carry-less multiplication of two 64-bit polynomials over the finite field GF(2) - in each of the 2 128-bit lanes.
- Compare packed signed 8-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed signed 32-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed double-precision (64-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed half-precision (16-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed single-precision (32-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed 32-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed 64-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for equality, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed signed 32-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed signed 32-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for greater-than, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed signed 32-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for less-than-or-equal, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed signed 32-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for less-than, and store the results in mask vector k.
- Compare packed signed 8-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed signed 16-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed 32-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed signed 64-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed unsigned 8-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed unsigned 16-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed unsigned 32-bit integers in a and b for not-equal, and store the results in mask vector k.
- Compare packed unsigned 64-bit integers in a and b for not-equal, and store the results in mask vector k.
- Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Test each 32-bit element of a for equality with all other elements in a closer to the least significant bit. Each element’s comparison forms a zero extended bit vector in dst.
- Test each 64-bit element of a for equality with all other elements in a closer to the least significant bit. Each element’s comparison forms a zero extended bit vector in dst.
- Compute the complex conjugates of complex numbers in a, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Convert packed 16-bit integers in a to packed 8-bit integers with truncation, and store the results in dst.
- Convert packed signed 16-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst.
- Convert packed 32-bit integers in a to packed 8-bit integers with truncation, and store the results in dst.
- Convert packed 32-bit integers in a to packed 16-bit integers with truncation, and store the results in dst.
- Convert packed signed 32-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst.
- Convert packed 64-bit integers in a to packed 8-bit integers with truncation, and store the results in dst.
- Convert packed 64-bit integers in a to packed 16-bit integers with truncation, and store the results in dst.
- Convert packed 64-bit integers in a to packed 32-bit integers with truncation, and store the results in dst.
- Convert packed signed 64-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst.
- Convert packed signed 64-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst. The upper 64 bits of dst are zeroed out.
- Convert packed signed 64-bit integers in a to packed single-precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed unsigned 16-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst.
- Convert packed unsigned 32-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst.
- Convert packed unsigned 32-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst.
- Convert packed unsigned 64-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst.
- Convert packed unsigned 64-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst. The upper 64 bits of dst are zeroed out.
- Convert packed unsigned 64-bit integers in a to packed single-precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in two 256-bit vectors a and b to packed BF16 (16-bit) floating-point elements, and store the results in a 256-bit wide vector. Intel’s documentation
- Convert packed BF16 (16-bit) floating-point even-indexed elements stored at memory locations starting at location a to single precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point even-indexed elements stored at memory locations starting at location a to single precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed BF16 (16-bit) floating-point odd-indexed elements stored at memory locations starting at location a to single precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point odd-indexed elements stored at memory locations starting at location a to single precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed single precision (32-bit) floating-point elements in a to packed BF16 (16-bit) floating-point elements, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed BF16 (16-bit) floating-point elements, and store the results in dst. Intel’s documentation
- Converts packed BF16 (16-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed signed 64-bit integers, and store the results in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 32-bit integers, and store the results in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 64-bit integers, and store the results in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst. The upper 64 bits of dst are zeroed out.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 16-bit integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed unsigned 16-bit integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit unsigned integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit unsigned integers, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed double-precision (64-bit) floating-point elements, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed signed 64-bit integers, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 32-bit integers, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 64-bit integers, and store the results in dst.
- Convert packed signed 16-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst.
- Convert packed signed 32-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst.
- Convert packed signed 32-bit integers in a to packed 16-bit integers with signed saturation, and store the results in dst.
- Convert packed signed 64-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst.
- Convert packed signed 64-bit integers in a to packed 16-bit integers with signed saturation, and store the results in dst.
- Convert packed signed 64-bit integers in a to packed 32-bit integers with signed saturation, and store the results in dst.
- Copy the lower half-precision (16-bit) floating-point element from
`a`

to`dst`

. - Convert packed double-precision (64-bit) floating-point elements in a to packed signed 64-bit integers with truncation, and store the result in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 32-bit integers with truncation, and store the results in dst.
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 64-bit integers with truncation, and store the result in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 16-bit integers with truncation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit integers with truncation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit integers with truncation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed unsigned 16-bit integers with truncation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit unsigned integers with truncation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit unsigned integers with truncation, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed signed 64-bit integers with truncation, and store the result in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 32-bit integers with truncation, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 64-bit integers with truncation, and store the result in dst.
- Convert packed unsigned 16-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst.
- Convert packed unsigned 32-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst.
- Convert packed unsigned 32-bit integers in a to packed unsigned 16-bit integers with unsigned saturation, and store the results in dst.
- Convert packed unsigned 64-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst.
- Convert packed unsigned 64-bit integers in a to packed unsigned 16-bit integers with unsigned saturation, and store the results in dst.
- Convert packed unsigned 64-bit integers in a to packed unsigned 32-bit integers with unsigned saturation, and store the results in dst.
- Convert packed half-precision (16-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst.
- Convert packed single-precision (32-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst.
- Compute the sum of absolute differences (SADs) of quadruplets of unsigned 8-bit integers in a compared to those in b, and store the 16-bit results in dst. Four SADs are performed on four 8-bit quadruplets for each 64-bit lane. The first two SADs use the lower 8-bit quadruplet of the lane from a, and the last two SADs use the uppper 8-bit quadruplet of the lane from a. Quadruplets from b are selected from within 128-bit lanes according to the control in imm8, and each SAD in each 64-bit lane uses the selected quadruplet at 8-bit offsets.
- Divide packed half-precision (16-bit) floating-point elements in a by b, and store the results in dst.
- Compute dot-product of BF16 (16-bit) floating-point pairs in a and b, accumulating the intermediate single-precision (32-bit) floating-point elements with elements in src, and store the results in dst. Intel’s documentation
- Multiply groups of 4 adjacent pairs of signed 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of signed 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of signed 8-bit integers in a with corresponding unsigned 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of signed 8-bit integers in a with corresponding unsigned 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding unsigned 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding unsigned 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding unsigned 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding unsigned 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of unsigned 16-bit integers in a with corresponding signed 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of unsigned 16-bit integers in a with corresponding signed 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of unsigned 16-bit integers in a with corresponding unsigned 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst.
- Multiply groups of 2 adjacent pairs of unsigned 16-bit integers in a with corresponding unsigned 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src with signed saturation, and store the packed 32-bit results in dst.
- Extract 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from a, selected with imm8, and store the result in dst.
- Extracts 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from a, selected with IMM8, and stores the result in dst.
- Extract 128 bits (composed of 4 packed 32-bit integers) from a, selected with IMM1, and store the result in dst.
- Extracts 128 bits (composed of 2 packed 64-bit integers) from a, selected with IMM8, and stores the result in dst.
- Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, accumulate to the corresponding complex numbers in c, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Fix up packed double-precision (64-bit) floating-point elements in a and b using packed 64-bit integers in c, and store the results in dst. imm8 is used to set the required flags reporting.
- Fix up packed single-precision (32-bit) floating-point elements in a and b using packed 32-bit integers in c, and store the results in dst. imm8 is used to set the required flags reporting.
- Multiply packed complex numbers in a and b, accumulate to the corresponding complex numbers in c, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

. - Multiply packed half-precision (16-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst.
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst.
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst.
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c to/from the intermediate result, and store the results in dst.
- Multiply packed complex numbers in a and b, and store the results in dst. Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

. - Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract the intermediate result from packed elements in c, and store the results in dst.
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst.
- Test packed double-precision (64-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k. imm can be a combination of:
- Test packed half-precision (16-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k. imm can be a combination of:
- Test packed single-precision (32-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k. imm can be a combination of:
- Convert the exponent of each packed double-precision (64-bit) floating-point element in a to a double-precision (64-bit) floating-point number representing the integer exponent, and store the results in dst. This intrinsic essentially calculates floor(log2(x)) for each element.
- Convert the exponent of each packed half-precision (16-bit) floating-point element in a to a half-precision (16-bit) floating-point number representing the integer exponent, and store the results in dst. This intrinsic essentially calculates
`floor(log2(x))`

for each element. - Convert the exponent of each packed single-precision (32-bit) floating-point element in a to a single-precision (32-bit) floating-point number representing the integer exponent, and store the results in dst. This intrinsic essentially calculates floor(log2(x)) for each element.
- Normalize the mantissas of packed double-precision (64-bit) floating-point elements in a, and store the results in dst. This intrinsic essentially calculates ±(2^k)*|x.significand|, where k depends on the interval range defined by interv and the sign depends on sc and the source sign.

The mantissa is normalized to the interval specified by interv, which can take the following values:

_MM_MANT_NORM_1_2 // interval [1, 2)

_MM_MANT_NORM_p5_2 // interval [0.5, 2)

_MM_MANT_NORM_p5_1 // interval [0.5, 1)

_MM_MANT_NORM_p75_1p5 // interval [0.75, 1.5)

The sign is determined by sc which can take the following values:

_MM_MANT_SIGN_src // sign = sign(src)

_MM_MANT_SIGN_zero // sign = 0

_MM_MANT_SIGN_nan // dst = NaN if sign(src) = 1 - Normalize the mantissas of packed half-precision (16-bit) floating-point elements in a, and store the results in dst. This intrinsic essentially calculates
`±(2^k)*|x.significand|`

, where k depends on the interval range defined by norm and the sign depends on sign and the source sign. - Normalize the mantissas of packed single-precision (32-bit) floating-point elements in a, and store the results in dst. This intrinsic essentially calculates ±(2^k)*|x.significand|, where k depends on the interval range defined by interv and the sign depends on sc and the source sign. The mantissa is normalized to the interval specified by interv, which can take the following values: _MM_MANT_NORM_1_2 // interval [1, 2) _MM_MANT_NORM_p5_2 // interval [0.5, 2) _MM_MANT_NORM_p5_1 // interval [0.5, 1) _MM_MANT_NORM_p75_1p5 // interval [0.75, 1.5) The sign is determined by sc which can take the following values: _MM_MANT_SIGN_src // sign = sign(src) _MM_MANT_SIGN_zero // sign = 0 _MM_MANT_SIGN_nan // dst = NaN if sign(src) = 1
- Performs an affine transformation on the packed bytes in x. That is computes a*x+b over the Galois Field 2^8 for each packed byte with a being a 8x8 bit matrix and b being a constant 8-bit immediate value. Each pack of 8 bytes in x is paired with the 64-bit word at the same position in a.
- Performs an affine transformation on the inverted packed bytes in x. That is computes a*inv(x)+b over the Galois Field 2^8 for each packed byte with a being a 8x8 bit matrix and b being a constant 8-bit immediate value. The inverse of a byte is defined with respect to the reduction polynomial x^8+x^4+x^3+x+1. The inverse of 0 is 0. Each pack of 8 bytes in x is paired with the 64-bit word at the same position in a.
- Performs a multiplication in GF(2^8) on the packed bytes. The field is in polynomial representation with the reduction polynomial x^8 + x^4 + x^3 + x + 1.
- Stores 8 32-bit integer elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale
- Scatter 64-bit integers from a into memory using 32-bit indices. 64-bit elements are stored at addresses starting at base_addr and offset by each 32-bit element in vindex (each index is scaled by the factor in scale). scale should be 1, 2, 4 or 8.
- Stores 4 double-precision (64-bit) floating-point elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale
- Stores 8 single-precision (32-bit) floating-point elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale
- Stores 4 32-bit integer elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale
- Stores 4 64-bit integer elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale
- Stores 4 double-precision (64-bit) floating-point elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale
- Stores 4 single-precision (32-bit) floating-point elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale
- Copy a to dst, then insert 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from b into dst at the location specified by imm8.
- Copy a to dst, then insert 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from b into dst at the location specified by IMM8.
- Copy a to dst, then insert 128 bits (composed of 4 packed 32-bit integers) from b into dst at the location specified by imm8.
- Copy a to dst, then insert 128 bits (composed of 2 packed 64-bit integers) from b into dst at the location specified by IMM8.
- Load 256-bits (composed of 8 packed 32-bit integers) from memory into dst. mem_addr must be aligned on a 32-byte boundary or a general-protection exception may be generated.
- Load 256-bits (composed of 4 packed 64-bit integers) from memory into dst. mem_addr must be aligned on a 32-byte boundary or a general-protection exception may be generated.
- Load 256-bits (composed of 16 packed half-precision (16-bit) floating-point elements) from memory into a new vector. The address must be aligned to 32 bytes or a general-protection exception may be generated.
- Load 256-bits (composed of 32 packed 8-bit integers) from memory into dst. mem_addr does not need to be aligned on any particular boundary.
- Load 256-bits (composed of 16 packed 16-bit integers) from memory into dst. mem_addr does not need to be aligned on any particular boundary.
- Load 256-bits (composed of 8 packed 32-bit integers) from memory into dst. mem_addr does not need to be aligned on any particular boundary.
- Load 256-bits (composed of 4 packed 64-bit integers) from memory into dst. mem_addr does not need to be aligned on any particular boundary.
- Load 256-bits (composed of 16 packed half-precision (16-bit) floating-point elements) from memory into a new vector. The address does not need to be aligned to any particular boundary.
- Counts the number of leading zero bits in each packed 32-bit integer in a, and store the results in dst.
- Counts the number of leading zero bits in each packed 64-bit integer in a, and store the results in dst.
- Multiply packed unsigned 52-bit integers in each 64-bit element of
`b`

and`c`

to form a 104-bit intermediate result. Add the high 52-bit unsigned integer from the intermediate result with the corresponding unsigned 64-bit integer in`a`

, and store the results in`dst`

. - Multiply packed unsigned 52-bit integers in each 64-bit element of
`b`

and`c`

to form a 104-bit intermediate result. Add the high 52-bit unsigned integer from the intermediate result with the corresponding unsigned 64-bit integer in`a`

, and store the results in`dst`

. - Multiply packed unsigned 52-bit integers in each 64-bit element of
`b`

and`c`

to form a 104-bit intermediate result. Add the low 52-bit unsigned integer from the intermediate result with the corresponding unsigned 64-bit integer in`a`

, and store the results in`dst`

. - Multiply packed unsigned 52-bit integers in each 64-bit element of
`b`

and`c`

to form a 104-bit intermediate result. Add the low 52-bit unsigned integer from the intermediate result with the corresponding unsigned 64-bit integer in`a`

, and store the results in`dst`

. - Shuffle 8-bit integers in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Shuffle 16-bit integers in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from idx when the corresponding mask bit is not set).
- Shuffle 32-bit integers in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from idx when the corresponding mask bit is not set).
- Shuffle 64-bit integers in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from idx when the corresponding mask bit is not set).
- Shuffle double-precision (64-bit) floating-point elements in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from idx when the corresponding mask bit is not set)
- Shuffle single-precision (32-bit) floating-point elements in a and b across lanes using the corresponding selector and index in idx, and store the results in dst using writemask k (elements are copied from idx when the corresponding mask bit is not set).
- Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, accumulate to the corresponding complex numbers in c, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Multiply packed complex numbers in a and b, accumulate to the corresponding complex numbers in c, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

. - Multiply packed double-precision (64-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c from/to the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c to/from the intermediate result, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c from/to the intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, add the negated intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract the intermediate result from packed elements in c, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, add the negated intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (the element is copied from c when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (elements are copied from c when the corresponding mask bit is not set).
- Compute the absolute value of packed signed 8-bit integers in a, and store the unsigned results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the absolute value of packed signed 16-bit integers in a, and store the unsigned results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the absolute value of packed signed 32-bit integers in a, and store the unsigned results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the absolute value of packed signed 64-bit integers in a, and store the unsigned results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed 8-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed 16-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed 32-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed 64-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed double-precision (64-bit) floating-point elements in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed half-precision (16-bit) floating-point elements in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed single-precision (32-bit) floating-point elements in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed signed 8-bit integers in a and b using saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed signed 16-bit integers in a and b using saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed unsigned 8-bit integers in a and b using saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Add packed unsigned 16-bit integers in a and b using saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Concatenate pairs of 16-byte blocks in a and b into a 32-byte temporary result, shift the result right by imm8 bytes, and store the low 16 bytes in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Concatenate a and b into a 64-byte immediate result, shift the result right by imm8 32-bit elements, and store the low 32 bytes (8 elements) in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Concatenate a and b into a 64-byte immediate result, shift the result right by imm8 64-bit elements, and store the low 32 bytes (4 elements) in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Performs element-by-element bitwise AND between packed 32-bit integer elements of a and b, storing the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the bitwise AND of packed 64-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the bitwise AND of packed double-precision (64-bit) floating point numbers in a and b and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Compute the bitwise AND of packed single-precision (32-bit) floating point numbers in a and b and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Compute the bitwise NOT of packed 32-bit integers in a and then AND with b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the bitwise NOT of packed 64-bit integers in a and then AND with b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute the bitwise NOT of packed double-precision (64-bit) floating point numbers in a and then bitwise AND with b and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Compute the bitwise NOT of packed single-precision (32-bit) floating point numbers in a and then bitwise AND with b and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Average packed unsigned 8-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Average packed unsigned 16-bit integers in a and b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Considers the input
`b`

as packed 64-bit integers and`c`

as packed 8-bit integers. Then groups 8 8-bit values from`c`

as indices into the bits of the corresponding 64-bit integer. It then selects these bits and packs them into the output. - Blend packed 8-bit integers from a and b using control mask k, and store the results in dst.
- Blend packed 16-bit integers from a and b using control mask k, and store the results in dst.
- Blend packed 32-bit integers from a and b using control mask k, and store the results in dst.
- Blend packed 64-bit integers from a and b using control mask k, and store the results in dst.
- Blend packed double-precision (64-bit) floating-point elements from a and b using control mask k, and store the results in dst.
- Blend packed half-precision (16-bit) floating-point elements from a and b using control mask k, and store the results in dst.
- Blend packed single-precision (32-bit) floating-point elements from a and b using control mask k, and store the results in dst.
- Broadcasts the lower 2 packed single-precision (32-bit) floating-point elements from a to all elements of dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Broadcast the 4 packed single-precision (32-bit) floating-point elements from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcasts the 2 packed double-precision (64-bit) floating-point elements from a to all elements of dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Broadcasts the lower 2 packed 32-bit integers from a to all elements of dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Broadcast the 4 packed 32-bit integers from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcasts the 2 packed 64-bit integers from a to all elements of dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Broadcast the low packed 8-bit integer from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcast the low packed 32-bit integer from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcast the low packed 64-bit integer from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcast the low double-precision (64-bit) floating-point element from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcast the low single-precision (32-bit) floating-point element from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Broadcast the low packed 16-bit integer from a to all elements of dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 32-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed double-precision (64-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed half-precision (16-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed single-precision (32-bit) floating-point elements in a and b based on the comparison operand specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed 32-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed 64-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for equality, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 32-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for greater-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 32-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for greater-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 32-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for less-than-or-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 32-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for less-than, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 8-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 16-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed 32-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed signed 64-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 8-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 16-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 32-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Compare packed unsigned 64-bit integers in a and b for not-equal, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set).
- Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, and store the results in dst using writemask k (the element is copied from src when corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Contiguously store the active 8-bit integers in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active 16-bit integers in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active 32-bit integers in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active 64-bit integers in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active double-precision (64-bit) floating-point elements in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active single-precision (32-bit) floating-point elements in a (those with their respective bit set in writemask k) to dst, and pass through the remaining elements from src.
- Contiguously store the active 8-bit integers in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Contiguously store the active 16-bit integers in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Contiguously store the active 32-bit integers in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Contiguously store the active 64-bit integers in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Contiguously store the active double-precision (64-bit) floating-point elements in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Contiguously store the active single-precision (32-bit) floating-point elements in a (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Test each 32-bit element of a for equality with all other elements in a closer to the least significant bit using writemask k (elements are copied from src when the corresponding mask bit is not set). Each element’s comparison forms a zero extended bit vector in dst.
- Test each 64-bit element of a for equality with all other elements in a closer to the least significant bit using writemask k (elements are copied from src when the corresponding mask bit is not set). Each element’s comparison forms a zero extended bit vector in dst.
- Compute the complex conjugates of complex numbers in a, and store the results in dst using writemask k (the element is copied from src when corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Convert packed single-precision (32-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).

Rounding is done according to the imm8[2:0] parameter, which can be one of: - Sign extend packed 8-bit integers in a to packed 16-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Sign extend packed 8-bit integers in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Sign extend packed 8-bit integers in the low 4 bytes of a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed 16-bit integers in a to packed 8-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Sign extend packed 16-bit integers in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Sign extend packed 16-bit integers in a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 16-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Convert packed 16-bit integers in a to packed 8-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed 32-bit integers in a to packed 8-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed 32-bit integers in a to packed 16-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Sign extend packed 32-bit integers in a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 32-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 32-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Convert packed signed 32-bit integers in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed 32-bit integers in a to packed 8-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed 32-bit integers in a to packed 16-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed 64-bit integers in a to packed 8-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed 64-bit integers in a to packed 16-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed 64-bit integers in a to packed 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 64-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed signed 64-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set). The upper 64 bits of dst are zeroed out.
- Convert packed signed 64-bit integers in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed 64-bit integers in a to packed 8-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed 64-bit integers in a to packed 16-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed 64-bit integers in a to packed 32-bit integers with truncation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Zero extend packed unsigned 8-bit integers in a to packed 16-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Zero extend packed unsigned 8-bit integers in the low 8 bytes of a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Zero extend packed unsigned 8-bit integers in the low 4 bytes of a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Zero extend packed unsigned 16-bit integers in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Zero extend packed unsigned 16-bit integers in the low 8 bytes of a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 16-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Zero extend packed unsigned 32-bit integers in a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 32-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 32-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Convert packed unsigned 64-bit integers in a to packed double-precision (64-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed unsigned 64-bit integers in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set). The upper 64 bits of dst are zeroed out.
- Convert packed unsigned 64-bit integers in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in two vectors a and b to packed BF16 (16-bit) floating-point elements and store the results in single vector dst using writemask k (elements are copied from src when the corresponding mask bit is not set). Intel’s documentation
- Convert packed single-precision (32-bit) floating-point elements in a to packed BF16 (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). Intel’s documentation
- Converts packed BF16 (16-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed signed 64-bit integers, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 64-bit integers, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set). The upper 64 bits of dst are zeroed out.
- Convert packed double-precision (64-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 16-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed unsigned 16-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit unsigned integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit unsigned integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed double-precision (64-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed signed 64-bit integers, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 32-bit integers, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 64-bit integers, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).

Rounding is done according to the imm8[2:0] parameter, which can be one of:\ - Convert packed signed 16-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 16-bit integers in a to packed 8-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed signed 32-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 32-bit integers in a to packed 16-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 32-bit integers in a to packed 8-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed signed 32-bit integers in a to packed 16-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed signed 64-bit integers in a to packed 8-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 64-bit integers in a to packed 16-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 64-bit integers in a to packed 32-bit integers with signed saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed signed 64-bit integers in a to packed 8-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed signed 64-bit integers in a to packed 16-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed signed 64-bit integers in a to packed 32-bit integers with signed saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed double-precision (64-bit) floating-point elements in a to packed 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed signed 64-bit integers with truncation, and store the result in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed double-precision (64-bit) floating-point elements in a to packed unsigned 64-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 16-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed unsigned 16-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 32-bit unsigned integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed half-precision (16-bit) floating-point elements in a to packed 64-bit unsigned integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed signed 64-bit integers with truncation, and store the result in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed double-precision (32-bit) floating-point elements in a to packed unsigned 32-bit integers with truncation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed unsigned 64-bit integers with truncation, and store the result in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Convert packed unsigned 16-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 16-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed unsigned 32-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 32-bit integers in a to packed unsigned 16-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 32-bit integers in a to packed 8-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed unsigned 32-bit integers in a to packed unsigned 16-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed unsigned 64-bit integers in a to packed unsigned 8-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 64-bit integers in a to packed unsigned 16-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 64-bit integers in a to packed unsigned 32-bit integers with unsigned saturation, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Convert packed unsigned 64-bit integers in a to packed 8-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed unsigned 64-bit integers in a to packed 16-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed unsigned 64-bit integers in a to packed 32-bit integers with unsigned saturation, and store the active results (those with their respective bit set in writemask k) to unaligned memory at base_addr.
- Convert packed half-precision (16-bit) floating-point elements in a to packed single-precision (32-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Convert packed single-precision (32-bit) floating-point elements in a to packed half-precision (16-bit) floating-point elements, and store the results in dst using writemask k (elements are copied from src to dst when the corresponding mask bit is not set).
- Compute the sum of absolute differences (SADs) of quadruplets of unsigned 8-bit integers in a compared to those in b, and store the 16-bit results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). Four SADs are performed on four 8-bit quadruplets for each 64-bit lane. The first two SADs use the lower 8-bit quadruplet of the lane from a, and the last two SADs use the uppper 8-bit quadruplet of the lane from a. Quadruplets from b are selected from within 128-bit lanes according to the control in imm8, and each SAD in each 64-bit lane uses the selected quadruplet at 8-bit offsets.
- Divide packed double-precision (64-bit) floating-point elements in a by packed elements in b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Divide packed half-precision (16-bit) floating-point elements in a by b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Divide packed single-precision (32-bit) floating-point elements in a by packed elements in b, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Compute dot-product of BF16 (16-bit) floating-point pairs in a and b, accumulating the intermediate single-precision (32-bit) floating-point elements with elements in src, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). Intel’s documentation
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Multiply groups of 4 adjacent pairs of unsigned 8-bit integers in a with corresponding signed 8-bit integers in b, producing 4 intermediate signed 16-bit results. Sum these 4 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src, and store the packed 32-bit results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Multiply groups of 2 adjacent pairs of signed 16-bit integers in a with corresponding 16-bit integers in b, producing 2 intermediate signed 32-bit results. Sum these 2 results with the corresponding 32-bit integer in src using signed saturation, and store the packed 32-bit results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 8-bit integers from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 16-bit integers from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 32-bit integers from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 64-bit integers from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active double-precision (64-bit) floating-point elements from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active single-precision (32-bit) floating-point elements from a (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 8-bit integers from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 16-bit integers from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 32-bit integers from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active 64-bit integers from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active double-precision (64-bit) floating-point elements from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Load contiguous active single-precision (32-bit) floating-point elements from unaligned memory at mem_addr (those with their respective bit set in mask k), and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Extract 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from a, selected with imm8, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Extracts 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from a, selected with IMM8, and stores the result in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Extract 128 bits (composed of 4 packed 32-bit integers) from a, selected with IMM1, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Extracts 128 bits (composed of 2 packed 64-bit integers) from a, selected with IMM8, and stores the result in dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, accumulate to the corresponding complex numbers in c, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Multiply packed complex numbers in a by the complex conjugates of packed complex numbers in b, and store the results in dst using writemask k (the element is copied from src when corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

, or the complex conjugate`conjugate = vec.fp16[0] - i * vec.fp16[1]`

. - Fix up packed double-precision (64-bit) floating-point elements in a and b using packed 64-bit integers in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set). imm8 is used to set the required flags reporting.
- Fix up packed single-precision (32-bit) floating-point elements in a and b using packed 32-bit integers in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set). imm8 is used to set the required flags reporting.
- Multiply packed complex numbers in a and b, accumulate to the corresponding complex numbers in c, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

. - Multiply packed double-precision (64-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, add the intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, alternatively add and subtract packed elements in c to/from the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, subtract packed elements in c from the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c from/to the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c to/from the intermediate result, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, alternatively subtract and add packed elements in c from/to the intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed complex numbers in a and b, and store the results in dst using writemask k (the element is copied from src when corresponding mask bit is not set). Each complex number is composed of two adjacent half-precision (16-bit) floating-point elements, which defines the complex number
`complex = vec.fp16[0] + i * vec.fp16[1]`

. - Multiply packed double-precision (64-bit) floating-point elements in a and b, add the negated intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract the intermediate result from packed elements in c, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, add the negated intermediate result to packed elements in c, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed double-precision (64-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Multiply packed half-precision (16-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (the element is copied from a when the corresponding mask bit is not set).
- Multiply packed single-precision (32-bit) floating-point elements in a and b, subtract packed elements in c from the negated intermediate result, and store the results in dst using writemask k (elements are copied from a when the corresponding mask bit is not set).
- Test packed double-precision (64-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set). imm can be a combination of:
- Test packed half-precision (16-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k using zeromask k (elements are zeroed out when the corresponding mask bit is not set). imm can be a combination of:
- Test packed single-precision (32-bit) floating-point elements in a for special categories specified by imm8, and store the results in mask vector k using zeromask k1 (elements are zeroed out when the corresponding mask bit is not set). imm can be a combination of:
- Convert the exponent of each packed double-precision (64-bit) floating-point element in a to a double-precision (64-bit) floating-point number representing the integer exponent, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates floor(log2(x)) for each element.
- Convert the exponent of each packed half-precision (16-bit) floating-point element in a to a half-precision (16-bit) floating-point number representing the integer exponent, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates
`floor(log2(x))`

for each element. - Convert the exponent of each packed single-precision (32-bit) floating-point element in a to a single-precision (32-bit) floating-point number representing the integer exponent, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates floor(log2(x)) for each element.
- Normalize the mantissas of packed double-precision (64-bit) floating-point elements in a, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates ±(2^k)*|x.significand|, where k depends on the interval range defined by interv and the sign depends on sc and the source sign.

The mantissa is normalized to the interval specified by interv, which can take the following values:

_MM_MANT_NORM_1_2 // interval [1, 2)

_MM_MANT_NORM_p5_2 // interval [0.5, 2)

_MM_MANT_NORM_p5_1 // interval [0.5, 1)

_MM_MANT_NORM_p75_1p5 // interval [0.75, 1.5)

The sign is determined by sc which can take the following values:

_MM_MANT_SIGN_src // sign = sign(src)

_MM_MANT_SIGN_zero // sign = 0

_MM_MANT_SIGN_nan // dst = NaN if sign(src) = 1 - Normalize the mantissas of packed half-precision (16-bit) floating-point elements in a, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates
`±(2^k)*|x.significand|`

, where k depends on the interval range defined by norm and the sign depends on sign and the source sign. - Normalize the mantissas of packed single-precision (32-bit) floating-point elements in a, and store the results in dst using writemask k (elements are copied from src when the corresponding mask bit is not set). This intrinsic essentially calculates ±(2^k)*|x.significand|, where k depends on the interval range defined by interv and the sign depends on sc and the source sign.

The mantissa is normalized to the interval specified by interv, which can take the following values:

_MM_MANT_NORM_1_2 // interval [1, 2)

_MM_MANT_NORM_p5_2 // interval [0.5, 2)

_MM_MANT_NORM_p5_1 // interval [0.5, 1)

_MM_MANT_NORM_p75_1p5 // interval [0.75, 1.5)

The sign is determined by sc which can take the following values:

_MM_MANT_SIGN_src // sign = sign(src)

_MM_MANT_SIGN_zero // sign = 0

_MM_MANT_SIGN_nan // dst = NaN if sign(src) = 1 - Performs an affine transformation on the packed bytes in x. That is computes a*x+b over the Galois Field 2^8 for each packed byte with a being a 8x8 bit matrix and b being a constant 8-bit immediate value. Each pack of 8 bytes in x is paired with the 64-bit word at the same position in a.
- Performs an affine transformation on the inverted packed bytes in x. That is computes a*inv(x)+b over the Galois Field 2^8 for each packed byte with a being a 8x8 bit matrix and b being a constant 8-bit immediate value. The inverse of a byte is defined with respect to the reduction polynomial x^8+x^4+x^3+x+1. The inverse of 0 is 0. Each pack of 8 bytes in x is paired with the 64-bit word at the same position in a.
- Performs a multiplication in GF(2^8) on the packed bytes. The field is in polynomial representation with the reduction polynomial x^8 + x^4 + x^3 + x + 1.
- Stores 8 32-bit integer elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 64-bit integer elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 double-precision (64-bit) floating-point elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 8 single-precision (32-bit) floating-point elements from a to memory starting at location base_addr at packed 32-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 32-bit integer elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 64-bit integer elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 double-precision (64-bit) floating-point elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Stores 4 single-precision (32-bit) floating-point elements from a to memory starting at location base_addr at packed 64-bit integer indices stored in vindex scaled by scale using writemask k (elements whose corresponding mask bit is not set are not written to memory).
- Copy a to tmp, then insert 128 bits (composed of 4 packed single-precision (32-bit) floating-point elements) from b into tmp at the location specified by imm8. Store tmp to dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Copy a to tmp, then insert 128 bits (composed of 2 packed double-precision (64-bit) floating-point elements) from b into tmp at the location specified by IMM8, and copy tmp to dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Copy a to tmp, then insert 128 bits (composed of 4 packed 32-bit integers) from b into tmp at the location specified by imm8. Store tmp to dst using writemask k (elements are copied from src when the corresponding mask bit is not set).
- Copy a to tmp, then insert 128 bits (composed of 2 packed 64-bit integers) from b into tmp at the location specified by IMM8, and copy tmp to dst using writemask k (elements are copied from src if the corresponding bit is not set).
- Load packed 32-bit integers from memory into dst using writemask k (elements are copied from src when the corresponding mask bit is not set). mem_addr must be aligned on a 32-byte boundary or a general-protection exception may be generated.