Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Microsoft Specific
Emits the Supplemental Streaming SIMD Extensions 3 (SSSE3) instruction phaddd. This instruction adds the elements of two 64-bit parameters.
__m64 _mm_hadd_pi32(
__m64 a,
__m64 b
);
Parameters
[in] a
A 64-bit parameter that contains two 32-bit signed integers.[in] b
A 64-bit parameter that contains two 32-bit signed integers.
Return value
A 64-bit value that contains two 64-bit signed integers. Each integer is the sum between adjacent pairs of elements in the input parameters.
The result can be expressed with the following equations:
r0 := a0 + a1
r1 := b0 + b1
Requirements
Intrinsic |
Architecture |
---|---|
_mm_hadd_pi32 |
x86, x64 |
Header file <tmmintrin.h>
Remarks
r0, a0, and b0 are the lower 32 bits of return value r and of parameters a and b. r1, a1, and b1 are the higher order 32 bits of return value r and of parameters a and b.
Before you use this intrinsic, software must ensure that the underlying processor supports the instruction.
Example
#include <stdio.h>
#include <tmmintrin.h>
int main ()
{
__m64 a, b;
a.m64_i32[0] = 65535;
a.m64_i32[1] = -65536;
b.m64_i32[0] = 5000;
b.m64_i32[1] = 32000;
__m64 res = _mm_hadd_pi32(a, b);
printf_s("Original a:\t%6d\t%6d\nOriginal b:\t%6d\t%6d\n",
a.m64_i32[0], a.m64_i32[1], b.m64_i32[0], b.m64_i32[1]);
printf_s("Result res:\t%6d\t%6d\n",
res.m64_i32[0], res.m64_i32[1]);
_mm_empty();
return 0;
}
Original a: 65535 -65536 Original b: 5000 32000 Result res: -1 37000