インテル® C++ コンパイラー 18.0 デベロッパー・ガイドおよびリファレンス

加算組込み関数

このインテル® ストリーミング SIMD 拡張命令 3 補足命令 (インテル® SSSE3) 組込み関数は、水平加算に使用されます。これらの組込み関数のプロトタイプは、tmmintrin.h 内にあります。これらの組込み関数に対して ia32intrin.h ヘッダーファイルを使用することもできます。

_mm_hadd_epi16

extern __m128i _mm_hadd_epi16(__m128i a, __m128i b);

パックド符号付きワードを水平加算します。符号付き 16 ビット整数の配列として abr を解釈します。

for (i = 0; i < 4; i++) {
r[i] = a[2*i] + a[2i+1];
r[i+4] = b[2*i] + b[2*i+1];
}

_mm_hadd_epi32

extern __m128i _mm_hadd_epi32(__m128i a, __m128i b);

パックド符号付きダブルワードを水平加算します。符号付き 32 ビット整数の配列として abr を解釈します。

for (i = 0; i < 2; i++) {
r[i] = a[2*i] + a[2i+1];
r[i+2] = b[2*i] + b[2*i+1];
}

_mm_hadds_epi16

extern __m128i _mm_hadds_epi16(__m128i a, __m128i b);

符号付き飽和処理を使用して、パックド符号付きワードを水平減算します。符号付き 16 ビット整数の配列として abr を解釈します。

for (i = 0; i < 4; i++) {
r[i] = signed_saturate_to_word(a[2*i] + a[2i+1]);
r[i+4] = signed_saturate_to_word(b[2*i] + b[2*i+1]);
}

_mm_hadd_pi16

extern __m64 _mm_hadd_pi16(__m64 a, __m64 b);

パックド符号付きワードを水平加算します。符号付き 16 ビット整数の配列として abr を解釈します。

for (i = 0; i < 2; i++) {
r[i] = a[2*i] + a[2i+1];
r[i+2] = b[2*i] + b[2*i+1];
}

_mm_hadd_pi32

extern __m64 _mm_hadd_pi32(__m64 a, __m64 b);

パックド符号付きダブルワードを水平加算します。符号付き 32 ビット整数の配列として abr を解釈します。

r[0] = a[1] + a[0];
r[1] = b[1] + b[0];

_mm_hadds_pi16

extern __m64 _mm_hadds_pi16(__m64 a, __m64 b);

符号付き飽和処理を使用して、パックド符号付きワードを水平減算します。符号付き 16 ビット整数の配列として abr を解釈します。

for (i = 0; i < 2; i++) {
r[i] = signed_saturate_to_word(a[2*i] + a[2i+1]);
r[i+2] = signed_saturate_to_word(b[2*i] + b[2*i+1]);
}