インテル® C++ コンパイラー 19.1 デベロッパー・ガイドおよびリファレンス
インテル® ストリーミング SIMD 拡張命令 3 補足命令 (インテル® SSSE3) 組込み関数は、絶対値を計算するのに使用されます。これらの組込み関数のプロトタイプは、tmmintrin.h 内にあります。
これらの組込み関数を使用する場合、次のように immintrin.h ファイルをインクルードします。
#include <immintrin.h>
extern __m128i _mm_abs_epi8(__m128i a);
符号付きバイトの絶対値を計算します。符号付き 8 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 16; i++) { r[i] = abs(a[i]); }
extern __m128i _mm_abs_epi16(__m128i a);
符号付きワードの絶対値を計算します。符号付き 16 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 8; i++) { r[i] = abs(a[i]); }
extern __m128i _mm_abs_epi32(__m128i a);
符号付きダブルワードの絶対値を計算します。符号付き 32 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 4; i++) { r[i] = abs(a[i]); }
extern __m64 _mm_abs_pi8(__m64 a);
符号付きバイトの絶対値を計算します。符号付き 8 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 8; i++) { r[i] = abs(a[i]); }
extern __m64 _mm_abs_pi16(__m64 a);
符号付きワードの絶対値を計算します。符号付き 16 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 4; i++) { r[i] = abs(a[i]); }
extern __m64 _mm_abs_pi32(__m64 a);
符号付きダブルワードの絶対値を計算します。符号付き 32 ビット整数の配列として a と r を解釈します。
for (i = 0; i < 2; i++) { r[i] = abs(a[i]); }